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High Integration 16-Bit IVIicroprocessor 
iAPX86 Family 



DISTINCTIVE CHARACTERISTICS 



Integrated feature set 

- Enhanced 10MHz 8086-1 CPU 

- Clock generator 

- Two independent, high-speed DMA channels 

- Programmable interrupt controller 

- Three programmable 16-bit timers 

- Programmable memory and peripheral chip-select 
logic 

- Programmable wait state generator 

- Local bus controller 

Available in lOMHz (80186-10), 8MHz (80186) 
High performance processor 

- Two times the performance of the standard 8086 



- 4M byte/sec bus bandwidth interface 

Direct addressing capability to 1M byte of memory 
Completely object code compatible with all existing 
lAPX 86, 88 software 

- Ten new instruction types 

- Compatible with 29843/45, 29833/63, 8284, and 
8288 bus support components 

Optional numeric processor extension 
Available in 68-pin Plastic Leaded Chip Carrier (PLCC), 
Ceramic Leadless Chip Carrier (LCC), and Pin Grid Array 
(PGA) packages. 
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GENERAL DESCRIPTION 



The 80186 is a highly integrated 16-bit microprocessor. It 
effectively combines 1 5-20 of the most common lAPX 86 
system components onto one. The 80186 provides two 
times greater throughput than the standard 5MHz 8086. 
The 80186 is upward compatible with 8086 and 8088 



software and adds 10 new instruction types to the existing 
set. 

The 801 86 comes in a 68-pin package and requires a single 
±5V power supply. 
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CONNECTION DIAGRAMS 
Ceramic Leadless Chip Carrier (LCC*) 
Top Bottom 
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PIN NO. 1 MARK 



CD010500 

*LCC package placed in socket top down. 
Pin Grid Array (PGA) 
Pins Facing Up Pins Facing Down 
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PIN NO. t MABK 

Plastic Leaded Chip Carrier (PLCC**) 
Top Bottom 
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PIN NO. 1 MARK 



GS E7 ee 65 64 e3 62 61 60 5S SS 57 56 55 54 53 52 



*PLCC package placed in socket top up. 



ORDERING INFORMATION 
Commodity Products 

AMD commodity products are available in several packages and operating ranges. The order number (Valid Combination) i: 
formed by a combination of: a. Temperature Range 

b. Package Type 

c. Device Number 

d. Speed Option 

e. Optional Processing 



I 



80186 



B 



Valid Combinations 


A, R, N 


80186 


80186-10 


A, R, lA, IR 


80186B 



e. OPTIONAL PROCESSING 

Blank = Standard Processing 
B = Burn in 



d. SPEED OPTION 

Blank = 8 MHz 
-10 = 10 MHz 



. DEVICE NUMBER/DESCRIPTION 

80186 

High-Integration 16-Bit Microprocessor 



b. PACKAGE TYPE 

R = 68-Pin Ceramic Leadless Chip Carrier (CA2068) 

A = 68-Terminal Pin Grid Array (CGX068) 

N - 68-Pin Plastic Leaded Ctiip Carrier (PL 068) 



a. TEMPERATURE RANGE 

Blank = Commercial (0 to +70°C) 
I 'Industrial (-40 to ■i-85°C) 



Valid Combinations 

Valid Combinations list configurations planned to be 
supported in volume for this device. Consult the local AMD 
sales office to confirm availability of specific valid 
combinations, to ciieck on new^ly released valid combinations, 
and to obtain additional data on AMD's standard military 
grade products. 



PIN DESCRIPTION 



Pin No. 



Name 



I/O 



Description 



9, 43 



Vcc. Vcc 



System Power +5 volt power supply. 



26, 60 



Vss. Vss 



System Ground. 



57 



RESET 



Reset Output Indicates that the 80186 CPU Is being reset; and can be used as a system reset. It Is 
active HIGH, synchronized with the proc essor clock, and lasts an Integer number of clock periods 
corresponding to the length of the RES signal. 



59, 58 



XI, X2 



Crystal Inputs, XI and X2, provide an external connection for a fundamental mode parallel resonant 
crystal for the internal crystal oscillator. X1 can interface to an external clock Instead of a crystal. The 
Input or oscillator frequency is internally divided by two to generate the clock signal (CLKOUT). 
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CLKOUT 



Clock Output provides the system with a 50% duty cycle waveform. All device pin timings are specified 
relative to CLKOUT. CLKOUT has sufficient MOS drive capabilities for a numeric processor extension. 



re5 



System Reset causes the 80186 to Immediately terminate its present activity, clear the internal logic, 
and enter a dormant state. This signal may be asynchr onou s to the 80186 clo ck. T he 80186 begins 
fetching Instructions approximately 7 clock cycles after RES is returned HIGH. RES is required to be 
LOW for greater th an 4 c lock cycles and is Internally synchronized. For proper Initialization, the LOW-to- 
HIGH transition of RES must occur no sooner than 50 m icroseconds after power up. This inp ut Is 
provided with a Schmitt-trlgger to facilitate power-on RES generation via an RG network. When RES 
occurs, the 80186 will drive the status lines to an inactive level for one clock, and then tri-state them. 



TEST 



TEST Is examined by the WAIT ins tructio n. If the TEST input is HIGH when "WAIT" execution begins, 
instruction execution will suspend. TEST will be resampled until it g oes LO W, at which time execution 
will resume. If interrupts are enabled while the 80186 is waiting for TEST, interrupts will be serviced. 
This input is synchronized internally. 



20 

21 



TIVIR in 0, 
TIVIR 1N1 



Timer inputs are used either as clock or control signals, depending upon the programmed timer mode. 
These inputs are active HIGH (or LOW-to-HlGH transitions are counted) and internally synchronized. 



22 
23 



TMR OUT 0, 
TMR OUT 1 



O 
O 



Timer outputs are used to provide single pulse or continuous waveform generation, depending upon the 
timer mode selected. 



18 
19 



DRCX) 
DRQ1 



DMA Request is driven HIGH by an external device when it desires that a DMA channel (Channel or 1) 
perform a transfer. These signals are active HIGH, level-triggered, and Internally synchronized. 



Non-Maskable Interrupt is an edge-triggered input which causes a type 2 interrupt. NMI is not maskable 
internally. A transition from a LOW to HIGH initiates the Interrupt at the next instruction boundary. NMI is 
latched internally. An Nf^l duration of one clock or more will guarantee service. This input is internally 
synchronized. 



45, 44 

42 

41 



INTO, INT1 

INT2/ INTA0 

INT3/INTA1 



I 
I/O 
I/O 



fulaskable Interrupt Requests can be requested by strobing one of these pins. When configured as 
inputs, these pins are active HIGH. Interrupt Requests are synchronized internally. tNT2 and 1NT3 may 
be configured via software to provide active-LOW interrupt-acknowledge output signals. All interrupt 
inputs may be configured via software to be either edge- or level-triggereed. To ensure recognition, all 
interrupt requests must remain active until the interrupt is acknowledged. When iRMX mode is selected, 
the function of these pins changes (see Interrupt Controller section of this data sheet). 



A19/S6, 
A18/S5, 
A17/S4, 
A16/S3 



Address Bus Outputs (16-19) and Bus Cycle Status (3-6) reflect the four most significant address bits 
during Ti. These signals are active HIGH. During T2, T3, Tyy, and T4, status Information Is available on 
these lines as encoded below: 





Low 


High 


S6 


Processor Cycle 


DMA Cycle 



S3, S4, and S5 are defined as LOW during T2-T4. 



10-17 
1-8 



AD15-AD0 



I/O 



Address/Data Bus (0-15) signals constitute the time multiplexed me mory or I/O address (Ti) and data 
(T2, T3, Tw, and T4) bus. The bus is active HIGH. Ao is analogous to BHE for the lower byte of the data 
bus, pins D7 through Dq. It is LOW during Ti when a byte is to be transferred onto the lower portion of 
the bus in memory or I/O operations. 



During Ti the Bus High Enable signal should be u sed t o determine If data Is to be enabled onto the 
most significant half of the data bus, pins Dij-Db. BHE is LOW during Ti for read, write, an interrupt 
acknowledge cycles when a byte is to be transferred on the higher half of the bus. The 87 status 
information is available during T2, T3, and T4. S7 is logically equivalent to BHE. The signal is active 
LOW, and is tristated OFF during bus HOLD. 



BHi and AO Encodings | 


BHE Value 


AO Value 


Function 








Work Transfer 





1 


Byte Transfer on upper half of data bus (D15-D8) 


1 





Byte Transfer on lower half of data bus (D7-D0) 


1 


1 


Resewed 



ALE/QSO 



Address Latch Enable/Queue Status is provided by the 80186 to latch the address into the 8282/ 
8283 address latches. ALE is active HIGH. Addresses are guaranteed to be valid on the trailing edge of 
ALE. The ALE rising edge is generated off the rising edge of the CLKOUT immediately preceding Ti of 
the associated bus cycle, effectively one-half clock cycle earlier than In the standard 6086. The trailing 
edge is generated off the CLKOUT rising edge in Ti as in the 8086. Note that ALE is never floated. 



PIN DESCRIPTION (Cont.) 



Pin No. 



Name 



I/O 



Description 



63 



Write Strobe/Queue Status 1 indicates that ttie data on Itie bus is to be written into a memory or an I/O 
device. WR is active for Ta, T3, and Tw of any write cycle. It is active LOW, and floats during "HOLD." It 
is driven HIGH for one clock during Reset, and then floated. When the 80186 is in queue status mode, 
the ALE/QSO and WR/QS1 pins provide information about processor/instruction queue interaction. 



QS1 


QSO 


Queue Operation 








No queue operation 





1 


First opcode byte fetched from the queue 


1 


1 


Subsequent byte fetched from the queue 


1 





Empty the queue 



RD/QSMD 



Read Strobe indicates that the 80186 is performing a memory or I/O read cycle. RD is active LOW for 
T2, Ta, and Tw of any read cycle. It is guaranteed not to_go LOW in T2 until after the Address Bus is 
floated. RD is active LOW, and floats during "HOLD." RD is driven HIGH for one_clock during Reset, 
and then the output driver is floated. A weak internal pull-up mechanism on the RD line holds it HIGH 
when the line is not driven. During RESET the pin is sampled to determine whether the 80186 should 
provide ALE, WR, and RD, or if the Queue-Status should be provided. RD should be connected to GND 
to provide Queue-Status data. 



Asynchronous Ready informs the 80186 that the addressed memory space or I/O device will complete 
a data transfer. The ARDY input pin will accept an asynchronous input, and is active HIGH. Only the 
rising edge is internally synchronized by the 80186. This means that the falling edge of ARDY must be 
synchronized to the 80186 clock. If connected to Vqc, no WAIT states are inserted. Asynchronous 
ready (ARDY) or synchronous ready (SRDY) must be active to terminate a bus cycle. If line is unused, it 
may remain connected to Voc or it may be connected to Vss (in which case the programmer must 
initialize the part to inhibit the external pins). 



SRDY 



Synchronous Ready must be synchronized externally to the 80186. The use of SRDY provides a 
relaxed system-timing specification on the Ready input. This is accomplished by eliminating the one-half 
clock cycle which is required for internally resolving the signal level when using the ARDY input. This 
line is active HIGH. If this line is connected to Vcp no WAIT states are inserted. Asynchronous ready 
(ARDY) or synchronous ready (SRDY) must be active before a bus cycle is terminated. If line is unused, 
it may remain connected to Vcc or it may be connected to Vss (in which case the programmer must 
initialize the part to inhibit the external pins). 



LOCK output indicates tha t othe r system bus masters are not to gain control of the system bus while 
LOCK is active LOW. The LOCK signal is requested by the LOCK prefix instruction and is activated at 
the beginning of the first data cycle associated with the instruction following the LOCK prefix. It remains 
active until the completion of the instruction following the LOCK prefix. No prefetches will occur while 
LOCK is asserted. When executing more than one LOCK instruction, always make sure there are six 
bytes of co de be tween the end of the first LOCK instruction and the start of the second LOCK 
instruction. LOCK is active LOW, is driven HIGH for one clock during RESET, and then floated. 



SO, SI, S2 



Bus cycle status S0-S2 are encoded to provide bus-transaction information: 



80186 Bus Cycle Status Information { 


82 


sT 


so 


Bus Cycle Initiated 











Interrupt Acknowledge 








1 


Read I/O 





1 





Write I/O 





1 


1 


Halt 


1 








Instruction Fetch 


1 





1 


Read Data from Ivlemory 


1 


1 





Write Data to Memory 


1 


1 


1 


Passive (no bus cycle) 



The status pins float during "HOLD." _ 

S2 may be used as a logical 1^/10 indicator, and SI as a DT/R indicator. 
The status lines are driven HIGH for one clock during Reset, and then floated until a bus cycle begins. 



50 
51 



HOLD (input) 
HLDA (output) 



HOLD indicates that another bus master is requesting the local bus. The HOLD input is active HIGH. 
HOLD may be asynchronous with respect to the 801 86 clock. The 601 86 will issue a HLDA in response 
to a HOLD request at the end of T4 or Ti Simultaneous with the issuance of HLDA, the 80186 will float 
the local bus and control lines. After HOLD is detected as being LOW, the 801 86 will lower HLDA. When 
the 80186 needs to run another bus cycle, it will again drive the local bus and control lines. 



Upper Memory Chip Select is an active LOW output whenever a memory reference is made to the 
defined upper portion (1K -=25 6K block) of memory. This line is not floated during bus HOLD. The 
address range activating UCS is software programmable. 



Lower Memory Chip Select is active LOW whenever a memory reference is made to the defined lower 
portion (1 K-256K) of memory. This line is not floated during bus HOLD. The address range activating 
LCS is sofhvare programmable. 



38, 37, 36, 
35 



MCSO-3 



Mid-Range Memory Chip Select signals are active LOW when a memory reference is made to the 
defined mid-range portion of mem ory (8K-612K). Those lines are not floated during bus HOLD. The 
address ranges activating MCSO-3 are software programmable. 



25 peso 

27-30 PCS1-4 



Peripheral Chip Select signals 0-4 are active LOW when a reference is made to the defined peripheral 
area ( 65K byte I/O space). These lines are not floated during bus HOLD. The address ranges activating 
PCSO-4 are software programmable. 



PIN DESCRIPTION (Cont.) 



Pin No. 



39 



Name 



P^5/A1 



P556/A2 



DT/R 



I/O 



Description 



Peripheral Chip Select 5 or Latched A1 may be programmed to provide a sixth perip heral c hip select, or 
to provide an internally latched A1 signal. The address range aclivat inq PCS6 is software 
programmable. When programmed to provide latched A1, rather than PCS6, this pin will retain the 
previously latched value of A1 during a bus HOLD. A1 is active HIGH. 



Peripheral Chip Select 6 or Latched A2 may be programmed to provide a seventh pe riphera l chip select, 
or to provide an internally latched A2 signal. The address range activa ting PCS6 is software 
programmable. When programmed to provide latched A2, rather than PCS6, this pin will retain the 
previously latched value of A2 during a bus HOLD. A2 Is active HIGH. 



Data Transmit/Receive controls the direction of data flow through the external 29833/29863 data bus 
transceiver. When LOW, data is transferred to the 80186. When HIGH the 80186 places write data on 
the data bus. 



Data Enable is provided as a 29833/2 9863 data bus transceiver output enable. DEN is active LOW 
during each memory and I/O access. DEN is HIGH whenever DT/R changes state. 



DETAILED DESCRIPTION 
Introduction 

The following Functional Description describes ttie base archi- 
tecture of the 80186. The architecture is common to the 8086, 
8088, and 80286 microprocessor families as well. The 801 86 is 
a very high integration 16-bit microprocessor. It combines 15- 
20 of the most common microprocessor system components 
onto one chip while providing twice the performance of the 
standard 8086. The 80186 is object code compatible with the 
8086, 8088 microprocessors and adds 1 new instruction types 
to the existing 8086, 8088 instruction set. 

80186 BASE ARCHITECTURE 

The 8086, 8088, 80186, and 80286 family all contain the same 
basic set of registers, instructions, and addressing modes. The 
80186 processor is upward compatible with the 8086, 8088, 
and 80286 CPUs. 

Register Set 

The 80186 base architecture has fourteen registers as shown 
in Figures 3a and 3b. These registers are grouped into the 
following categories. 

General Registers 

Eight 16-bit general purpose registers used to contain arithme- 
tic and logical operands. Four of these (AX, BX, CX, and DX) 
can be used as 16-bit registers or split into pairs of separate 8- 
bit registers. 



Segment Registers 

Four 16-bit special purpose registers select, at any given time, 
the segments of memory that are immediately addressable for 
code, stack, and data. (For usage, refer to IVIemory Organiza- 
tion.) 

Base and Index Registers 

Four of the general purpose registers may also be used to 
determine offset addresses of operands in memory. These 
registers may contain base addresses or indexes to particular 
locations within a segment. The addressing mode selects the 
specific registers for operand and address calculations. 

Status and Control Registers 

Two 16-bit special purpose registers record or alter certain 
aspects of the 80186 processor state. These are the Instruc- 
tion Pointer Register, which contains the offset address of the 
next sequential instruction to be executed, and the Status 
Word Register, which contains status and control flag bits (see 
Figures 3a and 3b). 

Status Word Description 

The Status Word records specific characteristics of the result 
of logical and arithmetic instructions (bits 0, 2, 4, 6, 7, and 11) 
and controls the operation of the 80186 within a given 
operating mode (bits 8, 9, and 10). The Status Word Register 
is 16-bits wide. The function of the Status Word bits is shown 
in Table 2. 



16-BIT 

REGISTER 

r<AME 



BVTE 

ADDRESSABLE 

(6.BIT 

REGISTER 

NAMES 

SHOWN) 



AX 


AH 


AL 


ox 


OH 


DL 


ex 


CH 


CL 


ex 


BH 


BL 


BP 




SI 




01 




SP 





SPECIAL 
REGISTER 
FUNCTIONS 



MULTIPLV/DIVIDE 
I/O INSTRUCTIONS 



\ loop/Shift/repeat/count 



BASE REGISTERS 

INDEX REGISTERS 
STACK POINTER 



CS 




CODE SEGMENT SELECTOR 


OS 




DATA SEGMENT SELECTOR 


ss 




STACK SEGMENT SELECTOR 


ES 




EXTRA SEGMENT SELECTOR 




SEGMENT REGISTERS 

15 




F 




STATUS WORD 


IP 




INSTRUCTION POINTER 



GENERAL 
REGISTERS 



STATUS AND CONTROL 
REGISTERS 



TB000045 



Figure 3a. 80186 General Purpose Register Set 



STATUS FLAGS: 

CARRY 

PARITY 

AUXILIARY CARRY 

ZERO 

SIGN 

OVERFLOW 



STATUS WORD: 



K\\\mmM\i 



1. 



^ MT 



em: 



ISM 



OF 



CONTROL FLAGS: 
TRAP FLAG 
INTERRUPT ENABLE 
DIRECTION FLAG 



EM 



DF002910 



Figure 3b. Status Word Format 



Table 2. Status Word Bit Function 



Bit 
Position 


Name 


Function 





CF 


Carry Flag — Set on high-order bit carry 
or borrow; cleared otherwise. 


2 


PF 


Parity Flag — Set if low-order 8 bits or 
result contain an even number of 1-bits; 
cleared othenwise. 


4 


AF 


Set on carry from or borrow to the low 
order four bits of AL; cleared othenwise. 


6 


ZF 


Zero Flag — Set if result is zero; cleared 
othenwise. 


7 


SF 


Sign Flag — Set equal to high-order bit 
of result (0 if positive, 1 if negative). 


8 


TF 


Single Step Flag — Once set, a single 
step interrupt occurs after the next in- 
struction executes. TF is cleared by the 
single step interrupt. 


9 


IF 


Interrupt-enable Flag — When set, 
maskable interrupts will cause the CPU 
to transfer control to an interrupt vector 
specified location. 


10 


DF 


Direction Flag — Causes string instruc- 
tions to auto decrement the appropriate 
index register when set. Clearing DF 
causes auto Increment. 


11 


OF 


Overflow Flag — Set if the signed result 
cannot be expressed within the number 
of bits in the destination operand; 
cleared othenwise. 



Instruction Set 

The instruction set is divided into seven categories: data 
transfer, arithmetic, shift/rotate/logical, string manipulation, 
control transfer, high-level instructions, and processor control. 
These categories are summarized in Figure 4. 

An 80186 instruction can reference anywhere from zero to 
several operands. An operand can reside in a register, in the 
instruction itself, or in memory. Specific operand addressing 
modes are discussed later in this data sheet. 

Memory Organization 

Memory is organized in sets of segments. Each segment is a 
linear contiguous sequence of up to 64K (2^®) 8-bit bytes. 
Memory is addressed using a two-component address (a 
pointer) that consists of a 16-bit base segment and a 16-bit 
offset. The 16-bit base values are contained i one of four 
internal segment registers (code, data, stack, extra). The 
physical address is calculated by shifting the base value LEFT 
by four bits and adding the 16-bit offset value to yield a 20-bit 
physical address (see Figure 5). This allows for a 1 MByte 
physical address size. 

All instructions that address operands in memory must specifiy 
the base segment and the 16-bit offset value. For speed and 
compact instruction encoding, the segment register used for 
physical address generation is implied by the addressing 
mode used (see Table 3). These rules follow the way 
programs are written (see Figure 6) as independent modules 
that require areas for code and data, a stack, and access to 
external data areas. 

Special segment override instruction prefixes allow the implicit 
segment register selection rules to be overridden for special 
cases. The stack, data, and extra segments may coincide for 
simple programs. 



GENERAL PURPOSE 


MOV 


Move byte or word 


PUSH 


Push word onto stack 


POP 


Pop word off stack 


PUSHA 


Push all registers on stack 


POPA 


Pop all registers from stack 


XCHG 


Exchange byte or word 


XLAT 


Translate byte 


INPUT/OUTPUT 


IN 


Input byte or word 


OUT 


Output byte or word 


ADDRESS OBJECT 


LEA 


Load effective address 


LDS 


Load pointer using OS 


LES 


Load pointer using ES 


FLAG TRANSFER 


LAHF 


Load AH register from flags 


SAHF 


Store AH register in flags 


PUSHF 


Push flags onto stack 


POPF 


Pop flags off stack 




ADDITION 


ADD 


Add byte or word 


ADC 


Add byte or word with carry 


INC 


Increment byte or word by 1 


AAA 


ASCII adjust for addition 


DAA 


Decimal adjust for addition 


SUBTRACTION 


SUB 


Subtract byte or word 


SBB 


Subtract byte or word with borrow 


DEC 


Decrement byte or word by 1 


NEG 


Negate byte or word 


CMP 


Compare byte or word 


AAS 


ASCII adjust for subtraction 


DAS 


Decimal adjust for subtraction 


MULTIPLICATION 


MUL 


Multiply byte or word unsigned 


IMUL 


Integer multiply byte or word 


AAM 


ASCII adjust for multiply 


DIVISION 


DIV 


Divide byte or word unsigned 


IDIV 


Integer divide byte or word 


AAD 


ASCII adjust for division 


CBW 


Convert byte to word 


CWD 


Convert word to doubleword 


MOVS 


Move byte or word string 



INS 


Input bytes or word string 


OUTS 


Output bytes or word string 


CMPS 


Compare byte or word string 


SCAB 


Scan byte or word string 


LODS 


Load byte or word string 


STOS 


Store byte or word string 


REP 


Repeat 


REPE/ 
REPZ 


Repeat while equal/zero 


REPNE/ 
REPNZ 


Repeat while not equal/not zero 




LOGICALS 1 


NOT 


"Not" byte or word 


AND 


"And" byte or word 


OR 


"Inclusive or" byte or word 


XOR 


"Exclusive or" byte or word 


TEST 


"Test" byte or word 


SHIFTS 


SHL/SAL 


Shift logical/arithmetic left byte or word 


SHR 


Shift logical right byte or word 


SAR 


Shift arithmetic right byte or word 


ROTATES 


ROL 


Rotate left byte or word 


ROR 


Rotate right byte or word 


RCL 


Rotate through carry left byte or word 


RCR 


Rotate through carry right byte or word 




FLAG OPERATIONS | 


STC 


Set carry flag 


CLC 


Clear carry flag 


CMC 


Complement carry flag 


STD 


Set direction flag 


OLD 


Clear direction flag 


STI 


Set interrupt enable flag 


CLI 


Clear interrupt enable flag 


EXTERNAL SYNCHRONIZATION 


HLT 


Halt until interrupt or reset 


WAIT 


Wait for TEST pin active 


ESC 


Escape to extension processor 


LOCK 


Lock bus during next instruction 


NO OPERATION 


NOP 


No operation 


HIGH LEVEL INSTRUCTIONS 


ENTER 


Format stack for procedure entry 


LEAVE 


Restore stack for procedure exit 


BOUND 


Detects values outside prescribed range 



Figure 4. 80186 Instruction Set 
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CONDITIONAL TRANSFERS 



UNCONDITIONAL TRANSFERS 



JA/JNBE 



Jump if above/not below nor equal 



CALL 



Call procedure 



JAE/JNB 



Jump If above or equal/not below 



RET 



Return from procedure 



JB/JNAE 



Jump If below/not above nor equal 



JMP 



Jump 



JBE/JNA 



Jump If below or equal/not above 



JC 



Jump If carry 



ITERATION CONTROLS 



JE/JZ 



Jump If equal/zero 



JG/JNLE 



Jump If greater/not less nor equal 



LOOP 



Loop 



JGE/JNL 



Jump If greater or equal/not less 



LOOPE/LOOPZ 



Loop if equal/zero 



JL/JNGE 



Jump if less/not greater nor equal 



LOOPNE/LOOPNZ 



Loop If not equal/not zero 



JLE/JNG 



Jump if less or equal/not greater 



JCXZ 



Jump If register CX = 



JNC 



Jump if not carry 



JNE/JNZ 



Jump if not equal/not zero 



INTERRUPTS 



JNO 



Jump if not overflow 



JNP/JPO 



Jump if not parity/parity odd 



INT 



Interrupt 



JNS 



Jump If not sign 



INTO 



Interrupt if overflow 



JO 



Jump If overflow 



IRET 



Interrupt return 



JP/JPE 



Jump If parity/parity even 



JS 



Jump if sign 



Figure 4. 80186 Instruction Set (continued) 
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To access operands that do not reside In one of the four 
immediately available segments, a full 32-blt pointer can be 
used to reload both the base (segment) and offset values. 
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Figure 5. Two Component Address 



Table 3. Segment Register Selection Rule 



Memory 

Reference 

Needed 


Segment 

Register 

Used 


Implicit Segment 
Selection Rule 


Instructions 
Stack 

External 

Data 

(Global) 

Local Data 


Code (CS) 
Stack (88) 

Extra (ES) 
Data (DS) 


Instruction prefetch and im- 
mediate data. 

All stack pushes and pops; 
any memory references 
which use BP Register as a 
base register. 

All string instruction refer- 
ences which use the Dl reg- 
ister as an index. 

All other data references. 
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Figure 6. Segmented Memory Helps 
Structure Software 



Addressing Modes 

The 801 86 provides eight categories of addressing modes to 
specify operands. Two addressing modes are provided for 
instructions that operate on register or immediate operands: 

• Register Operand Mode: The operand is located in one of 
the 8- or 16-bit general registers. 

• Immediate Operand Mode: The operand is included in the 
instruction. 

Six modes are provided to specify the location of an operand 
in a memory segment. A memory operand address consists of 
two 16-bit components: a segment base and an offset. The 
segment base is supplied by a 16-bit segment register either 
implicity chosen by the addressing mode or explicitly chosen 
by a segment override prefix. The offset, also called the 
effective address, is calculated by summing any combination 
of the following three address elements: 

• the displacement (an 8- or 16-bit immediate value con- 
tained in the instruction); 

• the base (contents of either the BX or BP base registers); 
and 

• the Index (contents of either the SI or Dl index registers) 

Any carry out from the 16-bit addition is ignored. Eight-bit 
displacements are sign extended to 16-bit values. 

Combinations of these three address elements define the six 
memory addressing modes, described below. 

• Direct Mode: The operand's offset is contained in the 
instruction as an 8- or 16-bit displacement element. 

• Register Indirect Mode:Jhe operand's offset Is in one of the 
registers SI, Dl, BX, or BP. 

• Based Mode: The operand's offset is the sum of an 8- or 
1 6-bit displacement and the contents of a base register (BX 
or BP). 

• Indexed Mode: The operand's offset is the sum of an 8- or 
16-bit displacement and the contents of an index register 
(SI or Dl). 

• Based Indexed Mode: The operand's offset is the sum of 
the contents of a base register and an index register. 

• Based Indexed Mode with Displacement: The operand's 
offset is the sum of a base register's contents, an index 
register's contents, and an 8- or 16-bit displacement. 

Data Types 

The 80186 directly supports the following data types: 

• Integer: A signed binary numeric value contained in an 8-bit 
byte or a 16-bit word. All operations assume a 2's comple- 
ment representation. Signed 32 and 64 bit integers are 
supported using a numeric data processor. 

• Ordinal: An unsigned binary numeric value contained in an 
8-bit byte or a 16-bit word. 

• Pointer: A16-or32-bit quantity, composed of a 1 6-bit offset 
component oral 6-bit segment base component in addition 
to a 16-bit offset component. 

• String: A contiguous sequence of bytes or words. A string 
may contain from IK to 64K bytes. 

• ASCII: A byte representation of alphanumeric and control 
characters using the ASCII standard of character represen- 
tation. 

• BCD: A byte (unpacked) representation of the decimal 
digits 0-9. 

• Pacl<ed BCD: A byte (packed) representation of two deci- 
mal digits (0-9). One digit is stored in each nibble (4-bits) of 
the byte. 



• Floating Point: A signed 32-, 64-, or 80-bit real number 
representation. (Floating point operands are supported 
using a numeric data processor configuration.) 

In general, individual data elements must fit within defined 
segment limits. Figure 7 graphically represents the data types 
supported by the 80186. 
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I/O Space 

The I/O space consists of 64K 8-bit or 32K 16-bit ports. 
Separate instructions address the I/O space with either an 8- 
bit port address, specified in the instruction, or a 16-bit port 
address in the DX register, 8-bit port addresses are zero 
extended such that A^s-As are LOW. I/O port addresses 
00F8(H) through OOFF(H) are reserved. 

Interrupts 

An interrupt transfers execution to a new program location. 
The old program address (CS:IP) and machine state (Status 
Word) are saved on the stack to allow resumption of the 
interrupted program. Interrupts fall into three classes: hard- 
ware initiated, INT instructions, and instruction exceptions. 
Hardware initiated interrupts occur in response to an external 
input and are classified as non-maskable or maskable. 

Programs may cause an interrupt with an INT instruction. 
Instruction exceptions occur when an unusual condition, which 
prevents further instruction processing, is detected while 
attempting to execute an instruction. If the exception was 
caused by executing an ESC instruction with the ESC trap bit 
set in the relocation register, the return instruction will point to 
the ESC instruction, or to the segment override prefix immedi- 
ately preceding the ESC instruction if the prefix was present. 
In all other cases, the return address from an exception will 
point at the instruction immediately following the instruction 
causing the exception. 



Table 4. 80186 interrupt Vectors 





Vector 


Default 


Related 


Interrupt Name 


Type 


Priority 


Instructions 


Divide Error 





*1 


DIV, IDIV 


Exception 








Single Step 


1 


12**2 


All 


Interrupt 








NMI 


2 


1 


All 


Breakpoint 


3 


*1 


INT 


Interrupt 








INTO Detected 


4 


*1 


INTO 


Overflow 








Exception 








Array Bounds 


5 


*1 


BOUND 


Exception 








Unused-Opcode 


6 


*1 


Undefined 


Exception 






Opcodes 


ESC Opcode 


7 


*1*** 


ESC Opcodes 


Exception 








Timer Interrupt 


8 


2A**** 




Timer 1 Interrupt 


16 


2B**** 




Timer 2 Interrupt 


17 


2C**** 




Reserved 


9 


3 




DMA Interrupt 


10 


4 




DMA 1 Interrupt 


11 


5 




INTO Interrupt 


12 


6 




INT1 Interrupt 


13 


7 




INT2 Interrupt 


14 


8 




INT3 Interrupt 


15 


9 





A table containing up to 256 pointers defines the proper 
interrupt service routine for each interrupt. Interrupts 0-31, 
some of which are used for instruction exceptions, are 
reserved. Table 4 shows the 80186 predefined types and 
default priority levels. For each interrupt, an 8-bit vector must 
be supplied to the 80186 which identifies the appropriate table 
entry. Exceptions supply the interrupt vector internally. In 
addition, internal peripherals and noncascaded external inter- 
rupts will generate their own vectors through the internal 
interrupt controller. INT instructions contain or imply the vector 
and allow access to all 256 interrupts. Maskable hardware 
initiated interrupts supply the 8-bit vector to the CPU during an 
interrupt acknowledge bus sequence. Non-maskable hard- 
ware interrupts use a predefined internally supplied vector. 

Interrupt Sources 

The 80186 can service interrupts generated by software or 
hardware. The software interrupts are generated by specific 
instructions (INT, ESC, unused OP, etc.) or the results of 
conditions specified by instructions (array bounds check, 
INTO, DIV, IDIV, etc.) All interrupt sources are serviced by an 
indirect call through an element of a vector table. This vector 
table is indexed by using the interrupt vector type (Table 4), 
multiplied by four. All hardware-generated interrupts are sam- 
pled at the end of each instruction. Thus, the software 
interrupts will begin service first. Once the service routine is 
entered and interupts are enabled, any hardware source of 
sufficient priority can interrupt the service routine in progress. 

The software generated 80186 interrupts are described below. 

DIVIDE ERROR EXCEPTION (TYPE 0) 

Generated when a DIV or IDIV instuction quotient cannot be 
expressed in the number of bits in the destination. 



NOTES: 

*1. 



**2. 
**3. 



These are generated as the result of an instruction 

execution. 

This is handled as in the 8086. 

All three timers constitute one source of request to 

the interrupt controller. The Timer interrupts all have 

the same default priority level with respect to all other 

interrupt sources. However, they have a defined 

priority ordering amongst themselves. (Priority 2A is 

higher priority than 2B.) Each Timer interrupt has a 

separate vector type number. 

Default priorities for the interrupt sources are used 

only if the user does not program each source into a 

unique priority level. 

An escape opcode will cause a trap only if the proper 

bit is set in the peripheral control block relocation 

register. 



SINGLE-STEP INTERRUPT (TYPE 1) 

Generated after most instructions if the TF flag is set. 
Interrupts will not be generated after prefix instructions (e.g., 
REP), instructions which modify segment registers (e.g., POP 
DS), or the WAIT instruction. 

NON-MASKABLE INTERRUPT-NMI (TYPE 2) 

An external interrupt source which cannot be masked. 

BREAKPOINT INTERRUPT (TYPE 3) 

A one-byte version of the INT instruction. It uses 12 as an 
index into the service routine address table (because it is a 
type 3 interrupt). 



INTO DETECTED OVERFLOW EXCEPTION 
(TYPE 4) 

Generated during an INTO instruction if the OF bit Is set. 

ARRAY BOUNDS EXCEPTION (TYPE 5) 

Generated during a BOUND instruction if the array index is 
outside the array bounds. The array bounds are located in 
memory at a location indicated by one of the Instruction 
operands. The other operand indicates the value of the index 
to be checked. 

UNUSED OPCODE EXCEPTION (TYPE 6) 

Generated if execution is attempted on undefined opcodes. 

ESCAPE OPCODE EXCEPTION (TYPE 7) 

Generated if execution is attempted of ESC opcodes (D8H- 
DFH). This exception will only be generated if a bit In the 
relocation register is set. The return address of this exception 
will point to the ESC instruction causing the exception. If a 
segment override prefix preceded the ESC instruction, the 
return address will point to the segment override prefix. 

Hardware-generated internjpts are divided into two groups: 
maskable Interupts and non-maskable interrupts. The 80186 
provides maskable hardware Interrupt request pins INTO- 
INT3. In addition, maskable interrupts may be generated by 
the 80186 integrated DMA controller and the integrated timer 
unit. The vector types for these interrupts is shown in Table 4. 
Software enables these inputs by setting the Interrupt flag bit 
(IF) in the Status Word. The interrupt controller is discussed in 
the peripheral section of this data sheet. 

Further maskable interrupts are disabled while servicing an 
Interrupt because the IF bit is reset as part of the response to 
an interrupt or exception. The saved Status Word will reflect 
the enable status of the processor prior to the intermpt. The 
Interrupt flag will remain zero unless specifically set. The 
interrupt return instruction restores the Status Word, thereby 
restoring the original status of IF bit. If the interrupt return re- 
enables Interrupts, and another Interrupt is pending, the 80186 
will immediately service the highest-priority interrupt pending, 
i.e., no instructions of the main line program will be executed. 

Non-Maskable Interrupt Request (NMI) 

A non-maskable interrupt (NMI) is also provided. This Interrupt 
is serviced regardless of the state of the IF bit. A typical use of 
NMI would be to activate a power failure routine. The 
activation of this input causes an interrupt with an internally 
supplied vector value of 2. No external interrupt acknowledge 
sequence Is performed. The IF bit is cleared at the beginning 
of an NMI interrupt to prevent maskable interrupts from being 
serviced. 

Single-Step Interrupt 

The 80186 has an internal interrupt that allows programs to 
execute one instruction at a time. It is called the single-step 
interrupt and is controlled by the single-step flag bit (TF) in the 
Status Word. Once this bit is set, an internal single-step 
interrupt will occur after the next instruction has been execut- 
ed. The interrupt clears the TF bit and uses an internally 
supplied vector of 1 . The IRET instruction is used to set the TF 
bit and transfer control to the next instruction to be single- 
stepped. 

Initialization and Processor Reset 

Pro cesso r initialization or sta rtup is accomplished by driving 
the RES input pin LOW. RES forces the 80186 to terminate all 
execution and local bus activ ity. No instructio n or b us activity 
will occur as long as RES is active. After RES becomes 



Inactive and an internal processing interval elapses, the 801 86 
begins ex ecutio n with the instruction at physical location 
FFFFO(H). RES also sets some registers to predefined values 
as shown in Table 5. 

Table 5. 80186 Initial Register State after RESET 



status Word 


F002(H) 


Instruction Pointer 


OOOO(H) 


Code Segment 


FFFF(H) 


Data Segment 


0000(H) 


Extra Segment 


OOOO(H) 


Stack Segment 


0000(H) 


Relocation Register 


20FF(H) 


UMCS 


FFFB(H) 



80186 CLOCK GENERATOR 

The 80186 provides an on-chip clock generator for both 
internal and external clock generation. The clock generator 
features a crystal oscillator, a divide-by-two counter, synchro- 
nous and asynchronous ready inputs, and reset circuitry. 

Oscillator 

The oscillator circuit of the 80186 is designed to be used with 
a parallel resonant fundamental mode crystal. This is used as 
the time base for the 80186. The crystal frequency selected 
will be double the CPU clock frequency. Use of an LC or RC 
circuit is not recommended with this oscillator. If an external 
oscialltor is used, it can be connected directly to input pin XI in 
lieu of a crystal. The output of the oscillator is not directly 
available outside the 80186. The recommended crystal config- 
uration is shown in Figure 8. 
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Figure 8. Recommended 80186 Crystal 
Configuration 

Cloci< Generator 

The 80186 clock generator provides the 50% duty cycle 
processor clock for the 80186. It does this by dividing the 
oscillator output by 2 forming the symmetrical clock. If an 
external oscillator is used, the state of the clock generator will 
change on the falling edge of the oscillator signal. The 
CLKOUT pin provides the processor clock signal for use 
outside the 80186. This may be used to drive other system 
components. All timings are referenced to the output clock. 
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READY Synchronization 

The 80186 provides both synchronous and asynchronous 
ready inputs. Asynchronous ready synchronization is accom- 
plished by circuitry which samples ARDY in the middle of T2, 
T3 and again in the middle of each Tw until ARDY is sampled 
HIGH. One-half CLKOUT cycle of resolution time is used. Full 
synchronization is performed only on the rising edge of ARDY, 
i.e., the falling edge of ARDY must be synchronized to the 
CLKOUT signal if it will occur during T2 or Tw- HIGH-to-LOW 
transitions of ARDY must be performed synchronously to the 
CPU clock. 

A second ready input (SRDY) is provided to interface with 
externally synchronized ready signals. This input is sampled at 
the end of T2 and again at the end of each Tyv until it is 
sampled HIGH. By using this input rather than the asynchro- 
nous ready input, the half-clock cycle resolution time penalty is 
eliminated. 

This input must satisfy set-up and hold times to guarantee 
proper operation of the circuit. 

In addition, the 80186, as part of the integrated chip-select 
logic, has the capability to program WAIT states for memory 
and peripheral blocks. This is discussed in the Chip Select/ 
Ready Logic description. 

RESET Logic 

The 80186 provides both a RES input pin and a synchro nized 
RESET pin for use with other system components. The RES 
input pin on the 80186 is provided with hysteresis in order to 
facilitate power-on Reset generation via an RC network. 
RESET i s gua ranteed to remain active for at least five clocks 
given a RES input of at least six clocks. RES ET m ay be 
delayed up to two and one-half clocks behind RE5. 

Multi ple 80186 processors may be synchronized through the 
RES input pin, since this input resets both the processor and 
divide-by-two internal counter in the clock generator. In order 
to insure that the divide-by-two counter s all begin counting at 
the same time, the active going edge of RES must satisfy a 25 
ns setup time before the falling edge of the 80186 clock input 
In addition, in order to insure that all CPUs begin executing in 
the same clock cycle, the reset must satisfy a 25 ns setup time 
before the rising edge of the CLKOUT signal of all the 
processors. 

LOCAL BUS CONTROLLER 

The 801 86 provides a local bus controller to generate the local 
bus control signals. In addition, it employs a HOLD/HLDA 
protocol for relinquishing the local bus to other bus masters. It 
also provides control lines that can be used to enable external 
buffers and to direct the flow of data on and off the local bus. 

IVIemory/Peripheral Control 

The ^186 provides ALE, RD, and WR bus control signals. 
The RD and WR signals are used to strobe data from memory 
to the 80186 or to strobe data from the 80186 to memory. The 
ALE line provides a strobe to address latches for the multi- 
plexed address/data bus. The 801 86 local bus controller does 
not provide a memory /I/O signal. If this is required, the user 
will have to use the S2 signal (which will require external 
latching), make the memory and I/O spaces nonoverlapping, 
or use only the integrated chip-select circuitry. 

Transceiver Controi 

The 80186 generates two control signals to be connected to 
29833/29863 transceiver chips. This capability allows the 
addition of transceivers for extra buffering without adding 
external logic. These control lines, DT/R and Oen, are 



generated to control the flow of data through the transceivers. 
The operation of these signals is shown in Table 6. 

Table 6. Transceiver Control Signals Description 



Pin Name 


Function 


DEN (Data Enable) 

DT/R (Data Transmit/ 
Receive) 


Enables the output drivers of the 
transceivers. It is active LOW 
during memory, I/O, or INTA 
cycles. 

Determines the direction of trav- 
el through the transceivers. A 
HIGH level directs data away 
from the processor during write 
operations, while a LOW level 
directs data toward the proces- 
sor during a read operation. 



Local Bus Arbitration 

The 80186 uses a HOLD/HLDA system of local bus ex- 
change. This provides an asynchronous bus exchange mecha- 
nism. This means multiple masters utilizing the same bus can 
operate at separate clock frequencies. The 80186 provides a 
single HOLD/HLDA pari through which all other bus masters 
may gain cotnrol of the local bus. This requires external 
circuitry to arbitrate whcih external device will gain control of 
the bus from the 80186 when there is more than one alternate 
local bus master. When the 80186 relinquishes control of the 
local bus, it flo ats DEN, RD, WR, S0-S2, LOCK, AD0-AD15, 
A16-A19, BHE, and DT/R to allow another master to drive 
these lines directly. 

The 80186 HOLD latency time, i.e., the time between HOLD 
request and HOLD acknowledge, is a function of the activity 
occurring in the processor when the HOLD request is re- 
ceived. A HOLD request is the highest-priority activity request 
which the processor may receive: higher than instruction 
fetching or internal DMA cycles. However, if a Dr/IA cycle is in 
progress, the 80186 will complete the transfer before relin- 
quishing the bus. This implies that if a HOLD request is 
received just as a DMA transfer begins, the HOLD latency time 
can be as great as 4 bus cycles. This will occur if a DMA word 
transfer operation is taking place from an odd address to an 
odd address. This is a total of 16 clocks or more, if WAIT 
states are required. In addition, if locked transfers are per- 
formed, the HOLD latency time will be increased by the length 
of the locked transfer. 

Local Bus Controller and Reset 

Upon receipt of a RESET pulse from the RES input, the local 
bus controller will perform the following actions: 

• Drive DEN, RD, and WR HIGH for one clock cycle, then 
float. 

NOTE: RE is also provided with an internal pull-up de- 
vice to prevent the processor from inadvertently enter- 
ing Queue Status mode during reset. 

• Drive S0-S2 to the passive state (all HIGH) and then float. 

• Drive LOCK HIGH and th en fl oat. 

• Tristate ADO-15, A16-19, BHE, DT/R. 

• Drive ALE LOW (ALE is never floated). 

• Drive HLDA LOW. 

INTERNAL PERIPHERAL INTERFACE 

All the 80186 integrated peripherals are controlled via 16-bit 
registers contained within an internal 256-byte control block. 
This control block may be mapped into either memory or I/O 
space. Internal logic will recognize the address and respond to 
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the bus cycle. During bus cycles to internal registers, the bus 
controller will signal the operation externally (i.e., the RD, WR, 
status, address, data, etc., lines will be driven as in a normal 
bus cycle), but D15.0, SRDY, and ARDY will be ignored. The 
base address of the control block must be on an even 256- 
byte boundary (i.e., the lower 8 bits of the base address are all 
zeros). All of the defined registers within this control block may 
be read or written by the 801 86 CPU at any time. The location 
of any register contained within the 256-byte control block is 
determined by the current base address of the control block. 

The control block base address is programmed via a 16-bit 
relocation register contained within the control block at offset 
FEH from the base address of the control block (see Figure 9). 
It provides the upper 12 bits of the base address of the control 
block. Note that mapping the control register block into an 
address range corresponding to a chip-select range is not 
recommended (the chip select circuitry is discussed later in 
this date sheet), in addition, bit 12 of this register determines 
whether the control block will be mapped into I/O or memory 
space. If this bit is 1, the control block will be located in 
memory space, whereas if the bit is 0, the control block will be 
located in I/O space. If the control register block is mapped 
into I/O space, the upper 4 bits of the base address must be 
programmed as (since I/O addresses are only 1 6 bits wide). 

In addition to providing relocation information for the control 
block, the relocation register contains bits which place the 
interrupt controller into IRMX mode, and cause the CPU to 
interrupt upon encountering ESC instructions. At RESET, the 
relocation register is set to 20FFH. This causes the control 
block to start at FFOOH in I/O space. An offset map of the 256- 
byte control register block is shown in Figure 10. 



The integrated 80186 peripherals operate semiautonomously 
from the CPU. Access to them for the most part is via software 
read/write of the control and data locations in the control 
block. Most of these registers can be both read and written. A 
few dedicated lines, such as interrupts and DI^A request 
provide real-time communication between the CPU and pe- 
ripherals as in a more conventional system utilizing discrete 
peripheral blocks. The overall interaction and function of the 
peripheral blocks has not substantially changed. 

CHIP-SELECT/READY GENERATION LOGIC 

The 80186 contains logic which provides programmable chip- 
select generation for both' memories and peripherals. In 
addition, it can be programmed to provide READY (or WAIT 
state) generation. It can also provide latched address bits A1 
and A2. The chip-select lines are active for all memory and I/O 
cycles in their programmed areas, whether they be generated 
by the CPU or by the integrated DMA unit. 

Memory Chip Selects 

The 80186 provides 6 memory chip select outputs for 3 
address areas: upper memory, lower memory, and midrange 
memory. One each is provided for upper memory and lower 
memory, while four are provided for midrange memory. 

The range for each chip select is user-programmable and can 
be set to 2K, 4K, 8K, 1 6K, 32K, 64K, 1 28K (plus 1 K and 256K 
for upper and lower chip selects). In addition, the beginning or 
base address of the midrange memory chip select may also be 
selected. Only one chip select may be programmed to be 
active for any memory location at a time. All chip select sizes 
are in bytes, whereas 80186 memory is arranged in words. 
This means that if, for example, 16 64K x 1 memories are 
used, the memory block size will be 128K, not 64K. 
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Relocation Address Bits R19-R8 
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ET = ESC Trap/No ESC Trap (1/0) 

M/IO = Register block located in Memory/ I/O Space (1/0) 

RMX = Normal Interrupt Controller mode/ IRMX compatible Interrupt Controller mode (0/1) 



Figure 9. Relocation Register 
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Relocation Register 
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Interrupt Controller Registers 
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Figure 10. Internal Register Map 
Upper Memory CS 

The 80186 provides a chip select, called DCS, for the top of 
memory. The top of memory is usually used as the system 
memory because after reset the 80186 begins executing at 
memory location FFFFOH. 

The upper limit of memory defined by this chip select is always 
FFFFFH, while the lower limit is programmable. By program- 
ming the lower limit, the size of the select block is also 
defined. Table 7 shows the relationship between the base 
address selected and the size of the memory block obtained. 

Table 7. UMCS Programming Values 



Starting 






Address 


Memory 


UMCS Value 


(Base 


Block 


(Assuming 


Address) 


Size 


R0 = R1=R2 = 0) 


FFCOO 


IK 


FFF8H 


FF800 


2K 


FFB8H 


FFOOO 


4K 


FF38H 


FEOOO 


8K 


FE38H 


FCOOO 


16K 


FC38H 


F8000 


32K 


F838H 


FOOOO 


64K 


F038H 


EODOO 


128K 


E038H 


coooo 


256K 


C038H 



The lower limit of this memory block is defined in the UMCS 
register (see Figure 11). This register is at offset AOH in the 
internal control block. The legal values for bits 6-13 and the 
resulting starting address and memory block sizes are given in 
Table 7. Any combination of bits 6-1 3 not shown in Table 7 will 
result in undefined operation. After reset, the UMCS register is 
programmed for a IK area. It must be reprogrammed if a 
larger upper memory area is desired. 

Any internally generally 20-bit address whose upper 16-bits 
are greater than or equal to UMCS (with bits 0-5 "0") will 



cause UCS to be activated. UMCS bits R2-R0 are used to 
specify READY mode for the area of memory defined by this 
chip-select register, as explained below. 

Lower Memory CS 

The 80186 provides a chip select for low memory called LCS. 
The bottom of memory contains the interrupt vector table, 
starting at location OOOOOH. 

The lower limit of memory defined by this chip select is always 
OH, while the upper limit is programmable. By programming 
the upper limit, the size of the memory block is also defined. 
Table 8 shows the relationship between the upper address 
selected and the size of the memory block obtained. 

Table 8. LMCS Programming Values 





Memory 


LMCS Value 


Upper 


Block 


(Assuming 


Address 


Size 


RO = R1 = R2 = 0) 


003FFH 


IK 


0038H 


007FFH 


2K 


0078H 


OOFFFH 


4K 


00F8H 


01FFFH 


8K 


01F8H 


03FFFH 


16K 


03F8H 


07FFFH 


32K 


07F8H 


OFFFFH 


64K 


0FF8H 


1FFFFH 


128K 


1FF8H 


3FFFFH 


256K 


3FF8H 



The upper limit of this memory block is defined in the LMCS 
register (see Figure 1 2). This register is at offset A2H in the 
internal control block. The legal values for bits 6-1 5 and the 
resulting upper address and memory block sizes are given in 
Table 8. Any combination of bits 6-15 not shown in Table 8 will 
result in undefined operation. Aft er re set, the LMCS register 
value is undefined. However, the LCS chip-select line will not 
become active until the LMCS register is accessed. 

Any internally generated 20-bit address whose upper 16 bits 
are l ess than or equal to LMCS (with bits 0-5 "1") will cause 
LCS to be active. LMCS register bits R2-R0 are used to 
specify the READY mode for the area of memory defined by 
this chip-select register. 

Mid-Range Memory CS 

The 80186 provides four MCS lines which are active within a 
user-locatable memory block. This block can be located 
anywhere within the 80186 1M byte memory address space 
exclusive of the areas defined by UCS and LCS. Both the base 
address and size of this memory block are programmable. 

The size of the memory block defined by the midrange select 
lines, as shown in Table 9, is determined by bits 8-14 of the 
MFCS register (see Figure 13). This register is at location A8H 
in the internal control block. One and only one of bits 8-14 
must be set at a time. Unpredictable operation of the MCS 
lines will othenwise occur. Each of the four chip-select lines is 
active for one of the four equal contiguous divisions of the mid- 
range block. Thus, if the total block size is 23K, each chip 
select is active for 8 K of m emory with MCSO being active for 
the first range and MCS3 being active for the last range. 

The EX and MS in MFCS relate to peripheral functionally as 
described in a later section. 
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Table 9. MMCS Programming Values 



Total Block 


Individual 


MMCS Bits 


Size 


Select Size 


14-8 


8K 


2K 


0000001 B 


16K 


4K 


000001 OB 


32K 


8K 


00001 OOB 


64K 


16K 


0001000B 


128K 


32K 


0010000B 


256K 


64K 


0100000B 


51 2K 


128K 


1000000B 



The base address of the mid-range memory block is defined 
by bits 15-9 of the MMCS register (see Figure 14). This 
register is at offset A6H in the internal control block. These 
bits correspond to bits A19-A13 of the 20-bit memory address. 
Bits A12-A0 of the base address area always 0. The base 
address may be set at any integer multiple of the size of the 
total memory block selected. For example, if the midrange 
block size is 32K (or the size of the block for which each MCS 
line is active is 8K), the block could be located at 10000H or 
18000H, but not at 14000H, since the first few integer 
multiples of a 32K memory block are OH, 8000H, 10000H, 
18000H, etc. After reset, the contents o f bot h of these 
registers is undefined. However, none of the MCS lines will be 
active until both the MMCS and MFCS registers are accessed. 
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Figure 11. UMCS Register 
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Figure 12. LIMCS Register 
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Figure 13. MFCS Register 
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Figure 14. MMCS Register 



MMCS bits R2-R0 specify READY mode of operation for all 
mid-range chip selects. All devices in mid-range memory must 
use the same number of WAIT states. 

The 51 2K block size for the mid-range memory chip selects is 
a special case. When using 51 2K, the base address would 
have to be at either locations OOOOOH or 80000H. If it were to 
be programmed at OOOOOH when the LCS line was pro- 
grammed, there would be an inte rnal c onflict between the LCS 
ready generation logic and the MCS ready generation logic. 
Likewise, if the base address w ere pr ogrammed at 80000H, 
there wouldbe a conflict with the DCS ready generation logic. 
Since the LCS chip-se lect l ine does not become active until 
programmed, while the UCS line is active at reset, the memory 
base can be set only at O OOOOH. If this base address is 
selected, however, the LCS range must not be programmed. 



Peripheral Chip Selects 

The 80186 can generate chip selects for up to seven 
peripheral devices. These chip selects are active for seven 
contiguous blocks of 128 bytes above a programmable base 
address. This base address may be located in either memory 
or I/O space. 

Seven CS lines called PCSO-6 are generated by the 80186. 
The base address is user-programmable; however it can only 
be a multiple of IK bytes, i.e., the least significant 10 bits of 
the starting address are always 0. 

PCS5 and PCS6 can also be programmed to provide latched 
address bits A1 , A2. If so programmed, they cannot be used 
as peripheral selects. These outputs can be connected 
directly to the AO, A1 pins used for selecting internal registers 
of 8-bit peripheral chips. This scheme simplifies the hardware 
interface because the 8-bit registers of peripherals are simply 
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treated as 16-bit registers located on even boundaries in I/O 
space or memory space where only the lower 8-bits of the 
register are significant: the upper 8-bits are "don't cares." 

The starting address of the peripheral chip-select block is 
defined by the PACS register (see Figure 15). This register is 
located at offset A4H in the internal control blocl<. Bits 1 5-6 of 
this register correspond to bits 19-10 of the 20-bit Programma- 



ble Base Address (PBA) of the peripheral chip-select block. 
Bits 9-0 of the PBA of the peripheral chip-select block are all 
zeros. If the chip-select block is located in I/O space, bits 12- 
15 must be programmed zero, since the I/O address is only 16 
bits wide. Table 10 shows the address range of each 
peripheral chip select with respect to the PBA contained in 
PACS register. 
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Figure 15. PACS Register 



The user should program bits 15-6 to correspond to the 
desired peripheral base lo cation. PACS bits 0-2 are used to 
specify READY mode for PCS0-PCS3. 

Table 10. PCS Address Ranges 



PCS Line 


Active between Locations 


peso 


PBA —PBA +127 


PCS1 


PBA -HI 28 — PBA -f 255 


PCS2 


PBA + 256 — PBA + 383 


PCS3 


PBA -H 384 — PBA + 511 


PCS4 


PBA + 512 — PBA + 639 


PCS5 


PBA + 640 — PBA + 767 


PCS6 


PBA + 768 — PBA + 895 



The mode of operation of the peripheral chip selects is defined 
by the MPCS register (which is also used to set the size of the 
mid-range memory chip-select block, see Figure 16). This 
register is located at offset A8H in the int erna l contr ol block. 
Bit 7 is used to select the function of PGS5 and PCS6, while bit 
6 is used to select whether the peripheral chip selects are 
mapped into memory or I/O space. Table 11 describes the 
programming of these bits. After reset, the contents of both 
the MPCS and the PACS registers are undefined, however 
none of the PCS lines will be active until both of the MPCS and 
PACS registers are accessed. 

Table 11. IMS, EX Programming Values 



Bit 



MS 
EX 



Description 



1 = Peripherals mapped into memory space. 
= P eriphe rals mapped into I/O space. 

= 5 PCS lines. A1 , A2 provided. 

1 = 7 PCS lines. A1 , A2 are not provided. 



MPCS bits 0-2 are used to specify READY mode for PCS4- 
PCS6 as outlined below. 

READY Generation Logic 

The 80186 can generate a "READY" signal internally for each 
of the memory or peripheral CS lines. The number of WAIT 
states to be inserted for each peripheral or memory is 
programmable to provide 0-3 wait states for all accesses to 
the area for which the chip select is active. In addition, the 
80186 may be programmed to either ignore external READY 
for each chip- select range individually or to factor external 
READY with the integrated ready generator. 



READY control consists of 3 bits for each CS line or group of 
lines generated by the 80186. The interpretation of the ready 
bits is shown in Table 12. 

Table 12. READY Bits Programming 



R2 


R1 


RO 


Number of WAIT States Generated 











wait states, external RDY also used. 








1 


1 wait state inserted, external RDY also 
used. 





1 





2 wait states inserted, external RDY also 
used. 





1 


1 


3 wait states inserted, external RDY also 
used. 


1 








wait states, external RDY ignored. 


1 





' 


1 wait state inserted, external RDY 
ignored. 


1 


1 





2 wait states inserted, external RDY ig- 
nored. 


1 


1 


1 


3 wait states inserted, external RDY ig- 
nored. 



The internal ready generator operates in parallel with external 
READY, not in series if the external READY is used (R2 = 0). 
This means, for example, if the internal generator is set to 
insert two wait states, but activity on the external READY lines 
will insert four wait states, the processor will only insert four 
wait states, not six. This is because the two wait states 
generated by the internal generator overlapped the first two 
wait states generated by the external ready signal. Note that 
the external ARDY and SRDY lines are always ignored during 
cycles accessing internal peripherals. 

R2-R0 of each control word specifies the READY mode for the 
corresponding block, with the e xceptio n of the peripheral chip 
selects: R2-R0 of PACS s et the PCSO-3 READY mode, R2-R0 
of MPCS set the PCS4-6 READY mode. 

Chip Select/Ready Logic and Reset 

Upon reset, the Chip-Select/Ready Logic will perform the 
following actions: 

• All chip-select outputs will be driven HIGH. 

• Upon leaving RESET, the UCS line will be programmed to 
provide chip selects to a 1 K block with the accompanying 
READY control bits set at Oil to allow the maximum 
number of internal wait states in conjunction with external 
Ready consideration (i.e. UMCS resets to FFFBH). 
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Figure 16. MFCS Register 



• No other chip select or READY control registers have any 
predefined values after RESET. They will not become 
active until the CPU accesses their control registers. Both 
the PACS and MPCS registers must be accessed before 
the PCS lines will become active. 

DMA CHANNELS 

The 80186 DMA controller provides two independent high- 
speed DMA channels. Data transfers can occur between 
memory and I/O spaces (e.g., Memory to I/O) or within the 
same space (e.g., Memory to Memory or I/O to I/O). Data can 
be transferred either in bytes (8 bits) or in words (16 bits) to or 
from even or odd addresses. Each DMA channel maintains 
both a 20-bit source and destination pointer which can be 
optionally incremented or decremented after each data trans- 
fer (by one or two depending on byte or word transfers). Each 
data transfer consumes 2 bus cycles (a minimum of 8 clocks), 
one cycle to fetch data and the other to store data. This 
provides a maximum data transfer rate of one Mword/sec or 2 
MBytes/sec. 

DMA Operation 

Each channel has six registers in the control block which 
define each channel's specific operation. The control registers 



consist of a 20-bit Source pointer (2 words), a 20-bit Destina- 
tion pointer (2 words), a 16-bit Transfer Counter, and a 16-bit 
Control Word. The format of the DMA Control Blocks is shown 
in Table 13. The Transfer Count Register (TC) specifies the 
number of DMA transfers to be performed. Up to 64K byte or 
word transfers can be performed with automatic termination. 
The Control Word defines the channel's operation (see Figure 
18). All registers may be modified or altered during any DMA 
activity. Anyl changes made to these registers will be reflected 
immediately in DMA operation. 

Table 13. DIMA Control Block Format 



Register Name 


Register Address 


Ch. 


Ch. 1 


Control Word 

Transfer Count 

Destination Pointer (upper 4 bits) 

Destination Pointer 

Source Pointer (upper 4 bits) 

Source Pointer 


CAH 
C8H 
C6H 
C4H 
C2H 
COH 


DAH 
D8H 
D6H 

D4H 
D2H 
DOH 



20 BIT AOOER/SUBTRACTOR 



TRANSFER COUNTER CH. 1 



DEST ADRS. POINTER CH. 1 



SRC. ADRS. POINTER CH. 1 



TRANSFER COUNTER CH. 



DEST. ADRS. POINTER CH. 



SRC. ADRS. POINTER CH. 



C 



7^ 



<Z 



ADDER CONTROL 
LOGIC 



TIMER REOUEST 
( 



DMA 

CONTROL 

LOGIC 



H 



REQUEST 

SELECTION 

LOGIC 



DROO 



a 



CHANNEL CONTROL WORD 1 



CHANNEL CONTROL WORD 



INTERNAL ADDRESS/OATA BUS 



^ 



BD00357C 



Figure 17. DMA Unit Block Diagram 
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Figure 18. DMA Control Register 



DMA Channel Control Word Register 

Each DMA Channel Control Word determines the mode of 
operation for the particular 80186 DMA channel. This register 
specifies: 

• the mode of synchronization; 

• whether bytes or words will be transferred; 

• whether interrupts will be generated after the last transfer; 

• whether DMA activity will cease after a programmed 
number of DMA cycles; 

o the relative priority of the DMA channel with respect to the 
other DMA channel; 

o whether the source pointer will be incremented, decrement- 
ed, or maintained constant after each transfer; 

o whether the source pointer addresses memory or I/O 
space; 

o whether the destination pointer will be incremented, dec- 
remented, or maintained constant after each transfer; and 

o whether the destination pointer will address memory or I/O 
space. 

The DMA channel control registers may be changed while the 
channel is operating. However, any changes made during 
operation will affect the current DMA transfer. 

DMA Control Word Bit Descriptions 



SYN: 
(2 bits) 



B/W: 



ST/STOP: 



CHG/NOCHG: 



INT: 
TC: 



Byte/Word (0/1) Transfers. 

Start/ stop (1/0) Channel. 

Chang e/ Do not change (1/0) ST/ 
STOP bit. If this bit is set when writing 
to the control word, the ST/STOP bit 
will be programmed by the write to 
the control word. If this bit is cleared 
wh en writ ing the control word, the 
ST/STOP bit will not be altered. This 
bit is not stored; it will always be a 
on read. 

Enable Interrupts to CPU on byte 
count termination. 

If set, DMA will terminate when the 
contents of the Transfe r Cou nt 
register reach zero. The ST/STOP bit 
will also be reset at this point if TC is 
set. If this bit is cleared, the DMA unit 
will decrement the transfer count 
register for each DMA cycle, but the 
DMA transfer will not stop when the 
contents of the TC register reach 
zero. 



SOURCE: INC 

M/iO 
DEC 

DEST: INC 

M/iO 

DEC 



TDRQ 



Bit 3 



00 No synchronization 

NOTE: The ST bit will be cleared 
automatically when the contents 
of the TC register reach zero re 
gardless of the state of the bit. 

01 Source synchronization. 

10 Destination synchronization. 

11 Unused. 

Increment source pointer by 1 or 2 
(depends on B/W) after each 
transfer. 

Source pointer is in M/IO space (1/ 
0). 

Decrement source pointer by 1 or 2 
(depends on B/W) after each 
transfer. 

Increment destination pointer by 1 or 

2 (B/W) after each transfer. 

Destination pointer is in M/IO space 
(1/0). 

Decrement destination pointer by 1 
or 2 (depending on B/W) after each 
transfer. 

Channel priority-relative to other 
channel. 

low priority. 

1 high priority. 

Channels will alternate cycles if both 
set at same priority level. 

0: Disable DMA requests from timer 

2. 

1 : Enable DMA requests from timer 2. 

Bit 3 is not used. 



If both INC and DEC are specified for the same pointer, the 
pointer will remain constant after each cycle. 

DMA Destination and Source Pointer 
Registers 

Each DMA channel maintains a 20-bit source and a 20-bit 
destination pointer. Each of these pointers takes up two full 
16-bit registers in the peripheral control block. The lower four 
bits of the upper register contain the upper four bits of the 20- 
bit physical address (see Figure 18a). These pointers may be 
individually incremented or decremented after each transfer. If 
word transfers are performed the pointer is incremented or 
decremented by two. Each pointer may point into either 
memory or I/O space. Since the DMA channels can perform 
transfers to or from odd addresses, there is no restriction on 
values for the pointer registers. Higher transfer rates can be 
obtained if all word transfers are performed to even ad- 
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dresses, since tliis will allow data to be accessed in a single 
memory access. 

DMA Transfer Count Register 

Each DMA channel maintains a 16-bit transfer count register 
(TC). This register Is decremented after every DMA cycle, 
regardless of the state of the TC bit In the DMA Control 
Register. If the TC bit In the DMA control word Is set, however, 
DMA activity will terminate when the transfer count register 
reaches zero. 

DMA Requests 

Data transfers may be either source or destination synchro- 
nized, that is either the source of the data or the destination of 
the data may request the data transfer. In addition, DMA 
transfers may be unsynchronlzed; that is, the transfer will take 
place continually until the correct number of transfers has 
occurred. When source or unsynchronlzed transfers are per- 
formed, the DMA channel may begin another transfer immedi- 
ately after the end of a previous DMA transfer. This allows 
complete transfer to take place every 2 bus cycles or eight 
clock cycles (assuming no wait states). No prefetching occurs 



when destination synchronization is performed, however. Data 
will not be fetched from the source address until the destina- 
tion device signatis that it Is ready to receive it. When 
destination synchronized transfers are requested, the DMA 
controller will relinquish control of the bus after every transfer. 
If no other bus activity is Initiated, another DMA cycle will 
begin after two processor clocks. This is done to allow the 
destination device time to remove its request If another 
transfer is not desired. Since the DMA controller will relinquish 
the bus, the CPU can initiate a bus cycle. As a result, a 
complete bus cycle will often be Inserted between destination 
synchronized transfers. These lead to the maximum DMA 
transfer rates shown In Table 14. 

Table 14. Maximum DMA Transfer Rates 



Type of 

Synchronization 

Selected 


CPU Running 


CPU Halted 


Unsynchronlzed 
Source Synch 
Destination Synch 


2MBytes/sec 
2MBytes/sec 
1.3MBytes/sec 


2MBytes/sec 
2MBytes/sec 
1.5MBytes/sec 



HIGHER 
REGISTER 
ADDRESS 

LOWER 
REGISTER 
ADDRESS 



XXX 


XXX 


XXX 


A19-A16 


A15-A12 


A11-A6 


A7-A4 


A3-A0 



15 

XXX = DON'T CARE 

Figure 18a. DMA Memory Pointer Register Format 



DMA Acitnowledge 

No explicit DMA acknowledge pulse is provided. Since both 
source and destination pointers are maintained, a read from a 
requesting source, or a write to a requesting destination, 
should be used as the DMA acknowledge signal. Since the 
chip-select lines can be programmed to be active for a given 
block of memory or I/O space, and the DMA pointers can be 
programmed to point to the same given block, a chip-select 
line could be used to Indicate a DMA acknowledge. 

DMA Priority 

The DMA channels may be programmed such that one 
channel is always given priority over the other, or they may be 
programmed such as to alternate cycles when both have DMA 
requests pending. DMA cycles always have priority over 
internal CPU cycles except between locked memory accesses 
or word accesses the odd memory locations; however, an 
external bus hold takes priority over an Internal DMA cycle. 
Because an interrupt request cannot suspend a DMA opera- 
tion and the CPU cannot access memory during a DMA cycle, 
interrupt latency time will suffer during sequences of continu- 
ous DMA cycles. An NMI request, however, will cause all 
internal DMA activity to halt. This allows the CPU to quickly 
respond to the NMI request. 

DMA Programming 

DMA cycles will occur whenever the ST/STOP bit of the Control 
Register is set. If synchronized transfers are programmed, a 



DRQ must also have been generated. Therefore, the source 
and destination transfer pointers, and the transfer count register 
(If used) must be programmed before this bit is set. 

Each DMA register may be modified while the channel Is 
operating. If the CHG/NOCHG bit Is cleared when the control 
register is written, the ST/STOP bit of the control register will 
not be modified by the write. If multiple channel registers are 
modified. It is recommended that a LOCKED string transfer be 
used to prevent a DMA transfer from occurring between 
updates to the channel registers. 

DMA Channeis and Reset 

Upon RESET, the DMA channels will perform the following 
actions: 

• The Start/Stop bit for each channel will be rest to STOP. 

• Any transfer in progress Is aborted. 

TiMERS 

The 80186 provides three internal 16-blt programmable timers 
(see Figure 19). Two of these are highly flexible and are 
connected to four external pins (2 per timer). They can be 
used to count external events, time external events, generate 
nonrepetltlve waveforms, etc. The third timer is not connected 
to any external pins, and is useful for real-time coding and time 
delay applications. In addition, this third timer can be used as a 
prescaler to the other two, or as a DMA request source. 
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Figure 19. Timer Blocl< Diagram 



Timer Operation 

The timers are controlled by 1 1 1 6-bit registers in the internal 
peripheral control block. The configuration of these registers is 
shown in Table 15. The count register contains the current 
value of the timer. It can be read or written at any time 
independent of whether the timer is running or not. The value 
of this register will be incremented for each timer event. Each 
of the timers is equipped with a MAX COUNT register, which 
defines the maximum count the timer will reach. After reaching 
the MAX COUNT register value, the timer count value will 
reset to zero during that same clock, i.e., the maximum count 
value is never stored in the count register itself. Timers and 1 
are, in addition, equipped with a second MAX COUNT register, 
which enables the timers to alternate their count between two 
different MAX COUNT values programmed by the user. If a 
single MAX COUNT register is used, the timer output pin will 
switch LOW for a single clock, 2 clocks after the maximum 
count value has been reached. In the dual MAX COUNT 
register mode, the output pin will indicate which MAX COUNT 
register is currently in use, thus allowing nearly complete 
freedom in selecting waveform duty cycles. For the timers with 
two MAX COUNT registers, the RIU bit in the control register 
determines which is used for the comparison. 

Each timer gets serviced every fourth CPU-clock cycle, and 
thus can operate at speeds up to one-quarter the internal 
clock frequency (one-eighth the crystal rate). External clocking 
of the timers may be done at up to a rate of one-quarter of the 
internal CPU-clock rate (2 MHz for an 8 MHz CPU clock). Due 
to internal synchronization and pipelining of the timer circuitry, 
a timer output may take up to 6 clocks to respond to any 
individual clock or gate input. 



Since the count registers and the maximum count registers 
are all 16 bits wide, 16 bits of resolution are provided. Any 
Read or Write access to the timers will add one wait state to 
the minimum four-clock bus cycle. However, this is needed to 
synchronize and coordinate the internal data flows between 
the internal timers and the internal bus. 

The timers have several programmable options. 

• All three timers can be set to halt or continue on a terminal 
count. 

• Timers and 1 can select between internal and external 
clocks, alternate between MAX COUNT registers and be 
set to retrigger on external events. 

• The timers may be programmed to cause an interrupt on 
terminal count. 

These options are selectable via the timer mode/control word. 

Timer IMode/Control Register 

The mode/control register (see Figure 20) allows the user to 
program the specific mode of operation or check the current 
programmed status for any of the three integrated timers. 

Table 15. Timer Control Block format 



Register Name 


Register Offset 


Tmr. 


Tmr. 1 


Tmr. 2 


Mode/Control Word 
Max Count B 
Max Count A 
Count Register 


56H 
54H 
52H 
50H 


5EH 
5CH 
5AH 
58H 


66H 

not present 

62H 

60H 
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Figure 20. Timer Mode/Control Register 
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ALT: 

The ALT bit determines which of two MAX COUNT registers is 
used for count comparison. It ALT = 0, register A for that timer 
is always used, while if ALT = 1, the comparison will alternate 
between register A and register B when each maximum count 
is reached. This alternation allows the user to change one 
MAX COUNT register while the other is being used, and thus 
provides a method of generating nonrepetitive waveforms. 
Square waves and pulse outputs of any duty cycle are a 
subset of available signals obtained by not changing the final 
count registers. The ALT bit also determines the function of 
the timer output pin. If ALT is zero, the output pin will go LOW 
for one clock, the clock after the maximum count is reached. If 
ALT is one, the output pin will reflect the current MAX COUNT 
register being used (0/1 for B/A). 

CONT: 

Setting the CONT bit causes the associated timer to run 
continuously, while resetting it causes the timer to halt upon 
maximum count. If CONT = and ALT = 1 , the timer will count 
to the MAX COUNT register A value, reset, count to the 
register B value, reset, and halt. 

EXT: 

The external bit selects between internal and external clocking 
for the timer. The external signal may be asynchronous with 
respect to the 801 86 clock. If this bit is set, the timer will count 
LOW-to-HIGH transitions on the input pin. if cleared, it will 
count an internal clock while using the input pin for control. In 
this mode, the function of the external pin is defined by the 
RTG bit. The maximum input to output transition latency time 
may be as much as 6 clocks. However, clock inputs may be 
pipelined as closely together as every 4 clocks without losing 
clock pulses. 



The prescaler bit is ignored unless internal clocking has been 
selected (EXT = 0). If the P bit is a zero, the timer will count at 
one-fourth the internal CPU clock rate. If the P bit is a one, the 
output of timer 2 will be used as a clock for the timer. Note that 
the user must initialize and start timer 2 to obtain the prescaled 
clock. 

RTG: 

Retrigger bit is only active for internal clocking (EXT = 0). In 
this case it determines the control function provided by the 
input pin. 

If RTG = 0, the input level gates the internal clock on and off. 
If the input pin is HIGH, the timer will count; if the input pin is 
LOW, the timer will hold its value. As indicated previously, the 
input signal may be asynchronous with respect to the 801 86 
clock. 

When RTG = 1, the input pin detects LOW-to-HIGH transi- 
tions. The first such transition starts the timer running, clearing 
the timer value to zero on the first clock, and then increment- 
ing thereafter. Further transitions on the input pin will again 
reset the timer to zero, from which it will start counting up 
again. If CONT = 0, when the timer has reached maximum 
count, the EN bit will be cleared, inhibiting further timer activity. 

EN: 

The enable bit provides programmer control over the timer's 
RUN/HALT status. When set, the timer is enabled to incre- 
ment subject to the input pin constraints in the internal clock 
mode (discussed previously). When cleared, the timer will be 
inhibited from counting. All input pin transitions during the time 
EN is zero will be ignored. If CONT is zero, the EN bit is 
automatically cleared upon maximum count. 



INH: 

The inhibit bit allows for selective updating of the enable (EN) 
bit. If INH is a one during the write to the mode/control word, 
then the state of the EN bit will be modified by the write. If INH 
is a zero during the write, the EN bit will be unaffected by the 
operation. This bit is not stored; it will always be a on a read. 

INT: 

When set, the INT bit enables interrupts from the timer, which 
will be generated on every terminal count. If the timer is 
configured in dual MAX COUNT register mode, an Interrupt will 
be generated each time the value in MAX COUNT register A is 
reached, and each time the value in MAX COUNT register B is 
reached. If this enable bit is cleared after the interrupt request 
has been generated, but before a pending interrupt is ser- 
viced, the interrupt request will still be in force. (The request is 
latched in the Interrupt Controller.) 

MC: 

The Maximum Count bit is set whenever the timer reaches its 
final maximum count value. It the timer is configured in dual 
MAX COUNT register mode, this bit will be set each time the 
value in MAX COUNT register A is reached, and each time the 
value in MAX COUNT register B is reached. This bit is set 
regardless of the timer's interrupt-enable bit The MC bit gives 
the user the abliity to monitor timer status through software 
instead of through interrupts. 

RIU: 

The Register In Use bit indicates which MAX COUNT register 
is currently being used for comparison to the timer count 
value. A zero value indicates register A. The RIU bit cannot be 
written, i.e.. Its value is not affected when the control register 
is written. It is always cleared when the ALT bit is zero. 

Not all mode bits are provided for timer 2. Certain bits 
are hardwired as indicated below: 

ALT = 0, EXT = 0, P = 0, RTG = 0, RIU = 

Count Registers 

Each of the three timers has a 16-bit count register. The 
current contents of this register may be read or written by the 
processor at any time. If the register is written into while the 
timer is counting, the new value will take effect in the current 
count cycle. 

Max Count Registers 

Timers and 1 have two MAX COUNT registers, while timer 2 
has a single MAX COUNT register. These contain the number 
of events the timer will count. In timers and 1, the MAX 
COUNT register used can alternate between the two max 
count values whenever the current maximum count is 
reached. The condition which causes a timer to reset is 
equivalent between the current count value and the max count 
being used. This means that if the count is changed to be 
above the max count value, or if the max count value is 
changed to be below the current value, the timer will not reset 
to zero, but rather will count to its maximum value, "wrap 
around" to zero, then count until the max count is reached. 

Timers and Reset 

Upon RESET, the Timers will perform the following actions: 

• All EN (Enable) bits are reset preventing timer counting. 

• All SEL (Select) bits are reset to zero. This selects MAX 
COUNT register A, resulting in the Timer Out pins going 
HIGH upon RESET. 
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INTERRUPT CONTROLLER 

The 80186 can receive interrupts from a number of sources, 
both internal and external. The internal interrupt controller 
serves to merge these requests on a priority basis, for 
individual service by the CPU. Internal interrupt sources 
(Timers and DMA channels) can be disabled by their own 
control registers or by mask bits within the interrupt controller. 
The 80186 interrupt controller has its own control registers 
that set the mode of operation for the controller. 

The interrupt controller will resolve priority among requests 
that are pending simultaneously. Nesting is provided so 
interrupt service routines for lower priority interrupts may 
themselves be interrupted by higher priority interrupts. A block 
diagram of the interrupt controller is shown in Figure 21. 

The interrupt controller has a special iRMX 86 compatibility 
mode that allows the use of the 80186 within the iRMX 86 
operating system interrupt structure. The controller is set in 
this mode by setting bit 14 in the peripheral control block 
relocation register (see iRMX 86 Compatibility Mode section). 
In this mode, the internal 80186 interrupt controller functions 
as a "slave" controller to an external "master" controller. 
Special initialization software must be included to properly set 
up the 80186 interrupt controller in IRMX 86 mode. 

MASTER (NON-iRMX) MODE OPERATION 

Interrupt Controller External Interface 

For external interrupt sources, five dedicated pins are provid- 
ed. One of these pins is dedicated to NMI, non-maskable 
interrupt. This is typically used for power-fail interrupts, etc. 
The other four pins may function either as four interrupt input 
lines with internally generated interrupt vectors, as an interrupt 
line and an interrupt acknowledge line (called the "cascade 
mode") along with two other input lines with internally generat- 
ed interrupt vectors, or as two interrupt input lines and two 
dedicated interrupt acknowledge ouput lines. When the inter- 
rupt lines are configured in cascade mode, the 80186 interrupt 
controller will not generate internal interrupt vectors. 

External sources in the cascade mode use externally generat- 
ed int errupt vectors. When an interrupt is acknowledged, two 
INTA cycles are initiated and the vector is read into the 801 86 
on the second cycle. The capability to interface to external 
8259A programmable interrupt controllers is thus provided 
when the inputs are configured in cascade mode. 

Interrupt Controller Modes of Operation 

The basic modes of operation of the interrupt controller in non- 
IRMX mode are similar to the 8259A. The interrupt controller 
responds identically to internal interrupts in all three modes: 
the difference is only in the interpretation of function of the 



four external interrupt pins. The interrupt controller is set into 
one of these three modes by programming the correct bits in 
the INTO and INT1 control registers. The modes of interrupt 
controller operation are as follows: 

Fully Nested Mode 

When in the fully nested mode four pins are used as direct 
interrupt requests. The vectors for these four inputs are 
generated internally. An in-service bit is provided for every 
interrupt source. If a lower-priority device requests an interrupt 
while the in-service bit (IS) is set, no interrupt will be generated 
by the interrupt controller. In addition, if another interrupt 
request occurs from the same interrupt source while the 
inservice bit is set, no interrupt will be generated by the 
interrupt controller. This allows interrupt service routines to 
operate with interrupts enabled without being themselves 
interrupted by lower-priority interrupts. Since interrupts are 
enabled, higher-priority interrupts will be serviced. 

When a service routine is completed, the proper IS bit must be 
reset by writing the proper pattern to the EOl register. This is 
required to allow subsequent interrupts from this interrupt 
source and to allow servicing of lower-priority interrupts. An 
EOl command is issued at the end of the service routine just 
before the issuance of the return from interrupt instruction. If 
the fully nested structure has been upheld, the next highest- 
priority source with its IS bit set is then serviced. 

Cascade Mode 

The 801 86 has four interrupt pins and two of them have dual 
functions. In the fully nested mode the four pins are used as 
direct interrupt inputs and the corresponding vectors are 
generated internally. In the cascade mode, the four pins are 
configured into interrupt Input-dedicated acknowledge signal 
pairs. The interconnection is shown in Figure 22. INT O is an 
interrupt input interfaced to an 8259A, while INT2/INTA0 
serves as the dedicated interrupt acknowledge signal t o that 
peripheral. The same is true for INT1 and INT3/INTA1. Each 
pair can selectively be placed in the cascade or non-cascade 
mode by programming the proper value into INTO and INT1 
control registers. The use of the dedicated acknowledge 
signals eliminates the need for the use of external logic to 
generate INTA and device select signals. 

The primary cascade mode allows the capability to serve up to 
128 external interrupt sources through the use of external 
master and slave 8259As. Three levels of priority are created, 
requiring priority resolution in the 80186 interrupt controller, 
the master 8259As, and the slave 8259As. If an external 
interrupt is serviced, one IS bit is set at each of these levels. 
When the interrupt service routine is completed, up to three 
end-of-interrupt commands must be issued by the program- 
mer. 
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Figure 21. Interrupt Controller Block Diagram 



Special Fully Nested IVIode 

This mode is entered by setting the SFNIW bit in INTO or INT1 
control register. It enables complete nestability with external 
8259A masters. Normally, an interrupt request from an inter- 
rupt source will not be recognized unless the in-service bit for 
that source is reset. If more than one interrupt source is 
connected to an external interrupt controller, all of the 
interrupts will be tunneled through the same 80186 interrupt 
request pin. As a result, if the external interrupt controller 
receives a higher-priority interrupt, its interrupt will not be 
recognized by the 80186 controller until the 80186 in-service 
bit is reset. In special fully nested mode, the 80186 interrupt 
controller will allow interrupts from an external pin regardless 
of the state of the in-service bit for an interrupt source in order 
to allow multiple interrupts from a single pin. An in-service bit 
will continue to be set, however, to inhibit interrupts from other 
lower-priority 80186 interrupt sources. 

Special procedures should be followed when resetting IS bits 
at the end of interrupt service routines. Software polling of the 
external master's IS register is required to determine if there is 
more than one bit set. If so, the IS bit in the 80186 remains 
active and the next interrupt service routine is entered. 

Operation in a Polled Environment 

The controller may be used in a polled mode if interrupts are 
undesirable. When polling, the processor disables interrupts 
and then polls the interrupt controller whenever it is conve- 
nient. Polling the interrupt controller is accomplished by 
reading the Poll Word (Figure 9). bit 15 in the poll word 
indicates to the processor that an interrupt of high enough 
priority is requesting service. Reading the Poll Word causes 
the In-Service bit of the highest-priority source to be set. 

It is desirable to be able to read the Poll Word information 
without guaranteeing service of any pending interrupt, i.e., not 
set the indicated in-service bit. The 80186 provides a Poll 



Status Word in addition to the conventional Poll Word to allow 
this to be done. Poll Word information is duplicated in the Poll 
Status Word, but reading the Poll Status Word does not set 
the associated in-service bit. These words are located in two 
adjacent memory locations in the register file. 

Master Mode Features 

Programmable Priority 

The user can program the interrupt sources into any of eight 
different priority levels. The programming is done by placing a 
3-bit priority level (0-7) in the control register of each interrupt 
source. (A source with a priority level of 4 has higher priority 
over all priority levels from 5 to 7. Priority registers containing 
values lower than 4 have greater priority.) All interrupt sources 
have preprogrammed default priority levels (see Table 4). 

If two requests with the same programmed priority level are 
pending at once, the priority ordering scheme shown in Table 
4 is used. If the serviced interrupt routine reenables Interrupts, 
it allows other requests to be serviced. 

End-of-lnterrupt Command 

The end-of-interrupt (EOl) command is used by the program- 
mer to reset the In-Service (IS) bit when an interrupt service 
routine is completed. The EOl command is issued by writing 
the proper pattern to the EOl register. There are two types of 
EOl commands, specific and nonspecific. The nonspecific 
command does not specify which IS bit is reset. When issued, 
the intermpt controller automatically resets the IS bit of the 
highest priority source with an active service routine. A specific 
EOl command requires that the programmer send the interrupt 
vector type to the interrupt controller indicating which source's 
IS bit is to be reset. This command is used when the fully 
nested structure has been disturbed or the highest priority IS 
bit that was set does not belong to the service routine in 
progress. 



24 



Trigger Mode 

The four external interrupt pins can be programmed in eitlier 
edge- or level-trigger mode. Tlie control register for each 
external source has a level-trigger mode (LTM) bit. All interrupt 
inputs are active HIGH. In the edge sense mode or the level- 
trigger mode the interrupt request must remain active (HIGH) 
until the interrupt request is acknowledged by the 801 86 CPU. 
In the edge-sense mode, if the level remains high after the 
interrupt is acknowledged, the input is disabled and no further 
requests will be generated. The input level must go LOW for at 
least one clock cycle to reenable the input. In the level-trigger 
mode, no such provision is made: holding the interrupt input 
HIGH will cause continuous interrupt requests. 

Interrupt Vectoring 

The 80186 Interrupt Controller will generate interrupt vectors 
for the integrated DMA channels and the integrated Timers. In 
addition, the Interrupt Controller will generate interrupt vectors 
for the external interrupt lines if they are not configured in 
Cascade or Special Fully Nested Mode. The interrupt vectors 
generated are fixed and cannot be changed (see Table 4). 

Interrupt Controller Registers 

The Interrupt Controller register model is shown in Figure 23. It 
contains 15 registers. All registers can both be read or written 
unless specified otherwise. 

In-Service Register 

This register can be read from or written into. The format is 
shown in Figure 24. It contains the In-Service bit for each of 
the interrupt sources. The In-Service bit for each of the 
interrupt sources. The In-Service bit is set to indicate that a 
source's service routine is in progress. When an In-Service bit 
is set, the interrupt controller will not generate interrupts to the 
CPU when it receives interrupt requests from devices with a 



lower programmed priority level. The TMR bit is the In-Service 
bit for all three timers; the DO and D1 bits are the In-Service 
bits for the two DMA channels; the 10-13 are the In-Service 
bits for the external interrupt pins. The IS bit is set when the 
processor acknowledges an interrupt request either by an 
interrupt acknowledge or by reading the poll register. The IS 
bit is reset at the end of the interrupt service routine by an end- 
of-interrupt command issued by the CPU. 

Interrupt Request Register 

The internal interrupt sources have interrupt request bits inside 
the interrupt controller. The format of this register is shown in 
Figure 24. A read from this register yields the status of these 
bits. The TMR bit is the logical OR of all timer interrupt 
requests. DO and 01 are the interrupt request bits for the DMA 
channels. 

The state of the external interrupt input pins is also indicated. 
The state of the external interrupt pins is not a stored condition 
inside the interrupt controller, therefore the external interrupt 
bits cannot be written. The external interrupt request bits show 
exactly when an interrupt request is given to the interrupt 
controller, so if edge-triggered mode is selected, the bit in the 
register will be HIGH only after an inactive-to-aotive transition. 
For internal interrupt sources, the register bits are set when a 
request arrives and are reset when the processor acknowl- 
edges the requests. 

IVIask Register 

This is a 16-bit register that contains a mask bit for each 
interrupt source. The format for this register is shown in Figure 
24. A one in a bit position corresponding to a particular source 
serves to mask the source from generating interrupts. These 
mask bits are the exact same bits which are used in the 
individual control registers; programming a mask bit using the 
mask register will also change this bit in the individual control 
registers, and vice versa. 
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Figure 22. Cascade IMode Interrupt Connection 
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OFFSET 


INT3 CONTROL REGISTER 


3EH 


INT2 CONTROL REGISTER 


3CH 


INT1 CONTROL REGISTER 


3AH 


INTO CONTROL REGISTER 


38H 


DMA 1 CONTROL REGISTER 


36H 


DMA CONTROL REGISTER 


34H 


TIMER CONTROL REGISTER 


32H 


INTERRUPT CONTROLLER STATUS REGIS- 
TER 


30H 


INTERRUPT REQUEST REGISTER 


2EH 


IN-SERVICE REGISTER 


2CH 


PRIORITY MASK REGISTER 


2AH 


MASK REGISTER 


28H 


POLL STATUS REGISTER 


26H 


POLL REGISTER 


24H 


EOl REGISTER 


22H 



Priority i\/lasi< Register 

This register is used to masl< all interrupts below particular 
interrupt priority levels. The format of this register is shown in 
Figure 25. The code in the lower three bits of this register 
Inhibits Interrupts of priority lower (a higher priority number) 
than the code specified. For example, 100 written into this 
register masks interrupts of level five (101), six (110), and 
seven (111). The register is reset to seven (111) upon RESET 
so all interrupts are unmasl^ed. 

Interrupt Status Register 

This register contains general Interrupt controller status infor- 
mation. The format of this register is shown in Figure 26. The 
bits in the status register have the following functions: 

DHLTrDMA Halt Transfer; setting this bit halts all DMA 
transfers. It is automatically set whenever a non- 
maskable Inten-upt occurs, and It Is reset when an IRET 
instruction is executed. The purpose of this bit is to 
allow prompt service of all non-maskable internjpts. 
This bit may also be set by the CPU. 

IRTx: These three bits represent the Individual timer Interrupt 
request bits. These bits are used to differentiate the 
timer interrupts, since the timer IR bit in the Interrupt 
request register Is the "OR" function of all timer 
interrupt requests. Note that setting any one of these 
three bits Initiates an interrupt request to the interrupt 
controller. 



Figure 23. Interrupt Controller Registers 
(Non-iRIMX 86 Mode) 
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Figure 24. In-Service, Interrupt Request, and Mask Register Formats 
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Figure 25. Priority Mask Register Format 
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Figure 26. Interrupt Status Register Format 
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Tinner, DMA 0, 1; Control Registers 

These registers are the control words for all the internal 
interrupt sources. The format for these registers is shown in 
Figure 27. The three bit positions PRO, PR1, and PR2 
represent the programmable priority level of the interrupt 
source. The MSK bit inhibits interrupt requests from the 
interrupt source. The MSK bits in the individual control 
registers are the exact same bits as are in the Mask Register; 
modifying them in the individual control registers will also 
modify them in the Mask Register, and vice versa. 

INT0-INT3 Control Registers 

These registers are the control words for the tour external 
input pins. Figure 28 shows the format of the INTO and INT1 
Control registers; Figure 29 shows the format of the INT2 and 
INT3 Control registers. In cascade mode or special fully 
nested mode, the control words for INT2 and INT3 are not 
used. 

The bits in the various control registers are encoded as 
follows: 



PRO-2: Priority programming information. Highest priori- 
ty = 000, lowest priority =111. 



LTM: Level-trigger mode bit. 1 = level-triggered; 

= edge-triggered. Interrupt Input levels are ac- 
tive high. In level-triggered mode, an interrupt is 
generated whenever the external line is high. 



In edge-triggered mode, an interrupt will be 
generated only when this level is preceded by 
an inactive-to-active transition on the line. In 
both cases, the level must remain active until 
the interrupt is acknowledged. 



MSK; Mask bit, 1 = mask; = nonmask. 



C: 



SFNM: 



Cascade mode bit, 1 = cascade; = direct 



Special fully nested mode bit, 1 
= normal nested mode. 



■■ SFNM; 



EOl Register 

The end of the interrupt register is a command register which 
can only be written into. The format of this register is shown in 
Figure 30. It initiates an EOl command when written to by the 
80186 CPU. 

The bits in the EOl register are encoded as follows: 



Encoded information that specifies an interrupt 
source vector type as shown in Table 4. For ex- 
ample, to reset the In-Service bit for DMA channel 
0, these bits should be set to 01010, since the 
vector type for DMA channel is 10. Note that to 
reset the single In-Service bit for any of the three 
timers, the vector type for timer 0(8) should be 
written in this register. 
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Figure 27. Timer/DMA Control Register Formats 
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Figure 28. INT0/INT1 Control Register Formats 
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Figure 29. INT2/INT3 Control Register Formats 



NSPEC/: A bit that determines the type of EOl command. 

SPEC Nonspecific = 1 , Specific = 0. 

Poll and Poll Status Registers 

These registers contain polling information. The format of 
these registers is shown in Figure 31 . They can only be read. 
Reading the Poll register constitutes a software poll. This will 
set the IS bit of the highest priority pending internjpt. Reading 
the poll status register will not set the IS bit of the highest 
priority pending interrupt; only the status of pending interrupts 
will be provided. 



Encoding of the Poll and Poll Status register bits are as 
follows: 



Sx: Encoded information that indicates the vector type 

of the highest priority interrupting source. Valid only 
when INTREQ = 1. 



INTREQ: This bit determines if an interrupt request is pres- 
ent Interrupt Request = 1; no Interrupt Request = 0, 
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iRMX 86 COMPATIBILITY MODE 

This mode allows iRMX 86-80186 compatibility. The interrupt 
model of IRMX 86 requires one master and multiple slave 
8259AS in cascaded fashion. When IRMX mode is used, the 
internal 80186 interrupt controller will be used as a slave 
controller to an external master interrupt controller. The 
internal 80186 resources will be monitored through the inter- 
nal interrupt controller, while the external controller functions 
as the system master interrupt controller. 

Upon reset, the 80186 interrupt controller will be in the non- 
iRMX 86 mode of operation. To set the controller in the IRMX 
86 mode, bit 14 of the Relocation Register should be set. 

Because of pin limitations caused by the need to interface to 
an external 8259A master, the internal interrupt controller will 
no longer accept external inputs. There are however, enough 
80186 interrupt controller inputs (internally) to dedicate one to 
each timer. In this mode, each timer interrupt source has its 
own mask bit, IS bit, and control word. 

The iRMX 86 operating system requires peripherals to be 
assigned fixed priority levels. This is incompatible with the 
normal operation of the 80186 interrupt controller. Therefore, 
the initialization software must program the proper priority 



levels for each source. The required priority levels for the 
internal interrupt sources in IRMX mode are shown in Table 
16. 

Table 16. Internal Source Priority Level 



Priority Level 


interrupt Source 





Timer 


1 


(resen/ed) 


2 


DMA 


3 


DMA 1 


4 


Timer 1 


5 


Timer 2 



These level assignments must remain fixed in the IRMX 86 
mode of operation. 

iRMX 86 Mode External Interface 

The configuration of the 80186 with respect to an external 
8259A master is shown in Figure 32. The INTO input is used as 
the 80186 CPU interrupt input. INT3 functions as an output to 
send the 801 86 slave-interrupt-request to one of the 8 master- 
PlC-inputs. 
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Figure 30. EOl Register Format 
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Figure 31. Poll Register Format 



iffTi 
iNI^ 



MASTER 



INTA 
INT 



c 



-REQUESTS FROM 
-OTHER SLAVES 



SLAVE SELECT 



I^ 



C^ASCAOE 
ADDRESS DECODER 



8018« SLAVE INTERRUPT OUTPUT 



AF002810 



Figure 32. IRMX 86 Interrupt Controller interconnection 
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Correct master-slave interface requires decoding of the slave Figure 35. The interrupt request bits are set when a request 

addresses (CASO-2). Slave 8259As do this internally. Be- arrives from an internal source, and are rest when the 

cause of pin limitations, the 80186 salve address will have to processor acknowledges the request. 

be decoded externally. IN 1 1 is used as a slave-select input. 

Note that the slave vector address is transferred internally, but Mask Register 

the READY input must be supplied externally. _. . . , , . , . ._ ... 

This register contains a mask bit for each interrupt source. The 

INT2 is used as an acknowledge output, suitable to drive the format for this register is shown in Figure 35. If the bit in this 

INI A input of an 8259A. register corresponding to a particular interrupt source is set, 

any interrupts from that source will be masked. These mask 

Interrupt Nesting bits are exactly the same bits which are used in the individual 

iRMX 86 mode operation allows nesting of interrupt requests. <=°"'f°' registers, i.e., changing the state of a mask bit in this 

When an interrupt is acknowledged, the priority logic masks off register will also change the state of the mask bit in the 

all priority levels except those with equal or higher priority. individual interrupt control register corresponding to the bit. 

Vector Generation in the iRIMX 86 IMODE '^o"*™' Registers 

Vector generation In iRMX mode is exactly like that of an These registers are the control words for all the internal 
8259A slave. The interrupt controller generates an 8-bit vector interrupt sources. The format of these registers is shown in 
which the CPU multiplies by four and uses as an address into a Figure 36. Each of the timers and both of the DMA channels 
vector table. The significant five bits of the vector are user- liave their own Control Register, 
programmable while the lower three bits are generated by the .,,.,.. ^ ,. „ . „ ■ 

priority logic. These bits represent the encoding of the priority ^''^ "its of the Control Registers are encoded as follows: 
level requesting service. The significant five bits of the vector g.^n encoded field indicating a priority level for the 
are programmed by wnting to the Interrupt Vector register at ^ ^0,3 ^^^^^ ^^^y, 30^^00 must be programmed 
°«s«* 20H. a, 3pgci,ied levels. 

Specific End-Of-lnterrupt msk: mask bit for the priority level indicated by prx bits. 

In IRMX mode the specific EOl command operates to reset an 

in-service bit of a specific priority. The user supplies a 3-bit 

priority-level value that points to an in-service bit to be reset. 

The command is executed by writing the correct value in the OFFSET 


Specific EOl register at offset 22H. 

interrupt Controller Registers in the IRIVIX 
86 Mode 

All control and command registers are located inside the 
internal peripheral control block. Figure 33 shows the offsets 
of these registers. 

End-Of-lnterrupt Register 

The end-of-interrupt register is a command register which can 
only be written. The format of this register is shown in Figure 
34. It initiates an EOl command when written by the 80186 
CPU. 

The bits in the EOl register are encoded as follows: 

Lx: Encoded value indicating the priority of the 
IS bit to be reset. 

In-Service Register 

This register can be read from or written into. It contains the in- 
service bit for each of the internal sources. The format for this 
register is shown in Figure 35. Bit positions 2 and 3 corre- 
spond to the DMA channels; positions 0, 4, and 5 correspond 
to the integral timers. The source's IS bit is set when the 
processor acknowledges its interrupt request. 


LEVEL 5 CONTROL REGISTER 
(TIMER 2) 


3AH 
38H 
36H 
34H 
32H 
2EH 
2CH 
2AH 
28H 
22H 
20H 


LEVEL 4 CONTROL REGISTER 
(TIMER 1) 


LEVEL 3 CONTROL REGISTER 
(DMA 1) 


LEVEL 2 CONTROL REGISTER 
(DMA 0) 


LEVEL CONTROL REGISTER 
(TIMER 0) 


INTERRUPT-REQUEST REGISTER 


IN-SERVICE REGISTER 


PRIORITY-LEVEL MASK REGISTER 


MASK REGISTER 


SPECIFIC EOl REGISTER 


INTERRUPT VECTOR REGISTER 


Interrupt Request Register 

This register indicates which internal peripherals have interrupt Fi 
requests pending. The format of this register is shown in 


gure 33. Interrupt Controller Re 
(IRIVIXSe IVIode) 


gisters 
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Figure 34. Specific EQI Register Format 
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Figure 35. In-Service, Interrupt Request, and Mask Register Format 



Interrupt Vector Register 

This register provides the upper five bits of the interrupt vector 
address. The format of this register is shown in Figure 37. The 
interrupt controller itself provides the lower three bits of the 
interrupt vector as determined by the priority level of the 
interrupt request. 

The format of the bits in this register is: 

tx: 5-bit field indicating the upper five bits of the vector 
address. 

Priority-Level Mask Register 

This register indicates the lowest priority-level interrupt which 
will be serviced. 

The encoding of the bits in this register is: 



mx: 



3-bit encoded field indication priority-level value. All 
levels of lower priority will be masl<ed. 



Interrupt Controller and Reset 

Upon RESET, the interrupt controller will perform the following 
actions: 

• All SFNM bits reset to 0, implying Fully Nested Mode. 

• All PR bits in the various control registers set to 1. Tis 
places all sources at lowest priority (level 111). 

• All LTM bits reset to 0, resulting in edge-sense mode. 

• All Interrupt Service bits reset to 0. 

• All Interrupt Request bits reset to 0. 

• All MSK (Interrupt Mask) bits set to 1 (masl<). 

• All C (Cascade) bits reset to (non-cascade). 

• All PRM (Priority Mask) bits set to 1, implying no levels 
masked. 

• Initialized to non-lRMX 86 mode. 
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Figure 36. Control Word Format 
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Figure 37. Interrupt Vector Register Format 
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Figure 38. Priority Level Mask Register 
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Figure 39. Typical 80186 Computer 
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Figure 40. Typical 80186 lUluiti-Master Bus interface 
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ABSOLUTE MAXIMUM RATINGS 


OPERATING 

f 1 50°C Commercial (C) Devices 


RANGES 






Voltage on Any Pin with Temperat 
Respect to Grounri -1 OV to +7\J 


ure (Ta) to +70°c; 1 


(To) 


+110°C 








5 V +10% 


Stresses above those listed under ABSOLUTE MAXIMUM Industnal (1) Devices 


-40 to +flfi"'n 


RATINGS may cause permanent device failure. Functionality L 1 , T~>,~ 1 ,i',""^ ' 


5 V +5% 


at or above these limits is not implied. Exposure to absolute ■^"vv>y vuiioyc vvoo; 

maximum ratings for extended periods may affect device Operating ranges define those limits between 
reliability. functionality of the device Is guaranteed. 

DC CHARACTERISTICS 


which the 


Parameters 


Description 


Test Conditions 


lUin 


Max 


Units 


V|L 


Input Low Voltage 




-0.5 


+ 0.8 


Volts 


VlH 


Input High Voltage 

(All except XI and HbS) 




2.0 


Vcc + 0.5 


Volts 


V|H1 


Input High Voltage (RES) 




3.0 


Vcc + 0.5 


Volts 


Vol 


Output Low Voltage 


Ia = 2.5mA for S0-S2 

Ia = 2.0mA for all other outputs 




0.45 


Volts 


VOH 


Output High Voltage 


IOA = -400(.iA 


2.4 




Volts 


Ice 


Power Supply Current 


Ta = -40°C 




600" 


mA 


Ta = 0°C 




500 


Ta = 70»C 




375 


Ili 


Input Leakage Current 


OV < V|N < Vcc 




±10 


IjA 


Ilo 


Output Leakage Current 


0.45V < VouT < Vcc 




±10 


ma 


VCLO 


Clock Output Low 


Ia = 4.0mA 




0.6 


Volts 


VCHO 


Clock Output High 


lOA = -200mA 


4.0 




Volts 


VCLI 


Clock Input Low Voltage 




-0.5 


0.6 


Volts 


VCHI 


Clock Input High Voltage 




3.9 


Vcc +1.0 


Volts 


C|N 


Input Capacitance 






10 


PF 


ClO 


I/O Capacitance 






20 


pF 


SWITCHING CHARACTERISTICS 

PIN TIMING 

80186 Timing Requirements All Timings Measured At 1.5 Volts Unless Otherwise Noted 






80186-10 (10MHz) 


80186 (8MHz) 




Parameters 


Description 


Test Conditions 


Min 


Max 


Min 


Max 


Units 


TDVCL 


Data in Setup (A/D) 




15 




20 




ns 


TCLDX 


Data in Hold (A/D) 




8 




10 




ns 


TARYHCH 


Asynchronous Ready 
(AREADY) Active Setup Time 




15 




20 




ns 


TARYLCL 


AREADY Inactive Setup Time 




25 




35 




ns 


TCHARYX 


AREADY Hold Time 




15 




15 




ns 


TARYCHL 


AREADY Inactive Hold Time 




15 




15 




ns 


TSRYCL 


Synchronous Ready 

(SREADY) Transition Setup Time 




20 




20 




ns 


TCLSRY 


SREADY Transition Hold Time 




15 




15 




ns 


THVCL 


HOLD Setup" 




20 




25 




ns 


TINVCH 


INTR, NMI, TEST, TIMERIN, Setup 




25 




25 




ns 


TINVCL 


DRQO, DRQ1, Setup 




20 




25 




ns 


*To guarantee recognition at next clock. 
*'For Industrial Grade Parts only. 
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SWITCHING CHARACTERISTICS (Cont'd.) 
80186 Master Interface Timing Responses 


Parameters 


Description 


Test Conditions 


80186-10 (lOIMHz) 


80186 (8MHz) 


Units 


Min 


Max 


Min 


Max 


TCLAV 


Address Valid Delay 


Cl=20-200 pF all outputs 
except TCLTMV 


5 


44 


5 


55 


ns 


TCLAX 


Address Hold 


10 




10 




ns 


TCLAZ 


Address Float Delay 


TCLAX 


30 


TCLAX 


35 


ns 


TCHCZ 


Command Lines Float Delay 




40 




45 


ns 


TCHCV 


Command Lines Valid Delay 
(after float) 




46 




55 


ns 


TLHLL 


ALE Width 


TCLCL-30 




TCLCL-35 




ns 


TCHLH 


ALE Active Delay 




30 




35 


ns 


TCHLL 


ALE Inactive Delay 




30 




35 


ns 


TLUX 


Address Hold to ALE Inactive 


TCHCL-20 




TCHCL-25 




ns 


TCLDV 


Data Valid Delay 


10 


40 


10 


44 


ns 


TCLDOX 


Data Hold Time 


10 




10 




ns 


TWHDX 


Data Hold after WR 


TCLCL-34 




TCLCL-40 




ns 


TCVCTV 


Control Active Delayl 


5 


56 


10 


70 


ns 


TCHCTV 


Control Active Delay2 


10 


44 


10 


55 


ns 


TCVCTX 


Control Inactive Delay 


5 


44 


5 


55 


ns 


TCVDEX 


DEN Inactive Delay 
(Non-Write Cycle) 


10 


56 


10 


70 


ns 


TAZRL 


Address Float to RD Active 












ns 


TCLRL 


RD Active Delay 


10 


40 


5 


50 


ns 


TCLRH 


RD Inactive Delay 


10 


44 


10 


55 


ns 


TRHAV 


RD Inactive to Address Active 


TCLCL-40 




TCLCL-40 




ns 


TCLHAV 


HLDA Valid Delay 


5 


40 


5 


50 


ns 


TRLRH 


RD Width 


2TCLCL-46 




2TCLCL-50 




ns 


TWLWH 


WR Width 


2TCLCL-34 




2TCLCL-40 




ns 


TAVAL 


Address Valid to ALE Low 


TCLCH-19 




TCLCH-26 




ns 


TCHSV 


Status Active Delay 


10 


45 


10 


55 


ns 


TCLSH 


Status Inactive Delay 


10 


50 


10 


65 


ns 


TCLTMV 


Timer Output Delay 


100 pF Max. 




48 




60 


ns 


TCLRO 


Reset Delay 






48 




60 


ns 


TCHQSV 


Queue Status Delay 




28 




35 


ns 


TCHDX 


Status Hold Time 


10 




10 




ns 


TAVCH 


Address Valid to Clocl< High 


10 




10 




ns 


TCLLV 


LOCK Valid/Invalid Deloay 


5 


60 


5 


65 


ns 


80186 Chip-Select Timing Responses 


Parameters 


Description 


Test Conditions 


80186-10 (10MHz) 


80186 (8MHz) 


Units 


lUlin 


Max 


Min 


Max 


TCLCSV 


Chip-Select Active Delay 






45 




66 


ns 


TCXCSX 


Chip-Select Hold from 
Command Inactive 




35 




35 




ns 


TCHCSX 


Chip-Select Inactive Delay 




5 


32 


5 


35 


ns 
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SWITCHING CHARACTERISTICS (Cont'd.) 
80186 CLKIN Requirements 



Parameters 



Description 



Test Conditions 



80186-10 (10MHz) 



MIn 



lUax 



80186 (8l\/IHz) 



IMin 



IVIax 



Units 



TCKIN 



CLKIN Period 



TCKHL 



CLKIN Fall Time 



3.5 to 1.0 volts 



TCKLH 



CLKIN Rise Time 



1.0 to 3.5 volts 



TCLCK 



CLKIN Low Time 



1.5 volts 



CLKIN High Time 



1.5 volts 



80186 CLKOUT Timing (200 pF load) 



Parameters 



Description 



Test Conditions 



lUin 



lUlax 



IMin 



Max 



Units 



TCICO 



CLKIN to CLKOUT Skew 



TCLCL 



CLKOUT Period 



125 



TCLCH 



CLKOUT Low Time 



teTCLCL-ao 



V2TCLCL-7.5 



TCHCL 



CLKOUT Higti Time 



V2TCLCL-6.0 



V2TCLCL-7.5 



TCH1CH2 



CLKOUT Rise Time 



1.0 to 3.5 volts 



TCL2CL1 



CLKOUT Fall Time 



3.5 to 1 volts 



15 



All timings measured at 1.5 volts unless othenwise noted. 



SWITCHING TEST INPUT/OUTPUT WAVEFORM 



^ 1.5 —TEST POINTS— i- 1.5 H^ 



WF001870 



AC testing inputs are driven at 2.4V for a logic "1" and 0.45V for a iogio "0." Tlie clock is driven at 4.3V 
and 0.25V. Timing measurements are made at 1.5V for both a logic "1" and "0." 
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SWITCHING WAVEFORMS 
MAJOR CYCLE TIMING 



VCH 



VCL 



82 fS, ,So 



BHE/S7, 

A19/S6-A16/S3 



T, 
-TCLCL- 



TCHSV 



^^jn^ 



-/- 



TCHLH-» 

TCLAV-» 



WRITE CYCLE 



Rg, INTA, 
DT/R - Vo„ 



AD,5-ADti 



AD,5-A[H, 



DT/R 



^e 



TCL 



>r BHE/A,j-A 



I I / 

U--»J -«-TCL2CL1 y' 



-*TAVAL-»- ^ 



y. 



f 



TCLOV 
•TCLAX 



■^^ 



RD,WR, = Vo„ 
SHE = Vol 



SOFTWARE HALT-DT/R =Vol, 
RO, WR. INTA, DEN = Vqh 



PCS, TCLAV- 

MCS 

LCSi 
MCS 



A,5-A, 



^ 



X 



/note 3) I 



r 



S,-S3 



TCLCH 



T 



■^L 



\ 



3 



TCLAZ- 
TCLDOX- 



^- 




X 



INVALID ADDRESS 



^e 



TCVCTX-» 
■^TOVCL-* 



> 



TWHDX 



.TCHCZ 
N0TE1 



)- 



•■NOTE 
TCVCTX 



r 



TCHCSX- 
TCXCSX- 



■c 



;^ 
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SWITCHING WAVEFORMS (Cont'd.) 
MAJOR CYCLE TIMING (Cont'd.) 



CLKOUT 



VcN TCH1CH2 i_ 



T, 
-TCLCL- 



Tj Tw 

-TCH1CHZ 



READ CYCLE 



WR, INTA = Voi 




Notes: 

1. Following a Write cycle, the Local Bus is floated by the 80186 only when the 
80186 enters a "Hold Acknowledge" state. 

2. INTA occurs one clock later in RMX-mode. 

3. Status inactive just prior to T4. 
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SWITCHING WAVEFORMS (Cont'd.) 



\. 



TCLLV 



WF006231 



CLXOUT 



NMI, 

TEST 

INTO-3 

TIMERIN 



WF006240 



-^^^J 



\ 



I 
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SWITCHING WAVEFORMS (Cont'd.) 



r^^'VjT 



r 



HOLD-HLDA TIMING 



CLKOUT 



V^ 



\ - 



5lN ' 



A19/Se-A16/S3, 



RD.WR. 80186 

BHl, 

OT/fi, 
^-SO 



^V_/" 



.«.TCLHAV 

( 



r^^.j~^ 



L.J 



.A^ 



)<■■ y-^ ^^ 



)^ y-^ 
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SWITCHING WAVEFORMS (Cont'd.) 



X^ (CLKIN) 



M 



CLKOUT 



TCICO- 



*. -^TCLCK- 






-TCKLH 



r 



TCHCK 



WF006292 



TIMER ON 80186 






TIMEROUT 



-TINVCH 



WF006300 



80186 INSTRUCTION TIMINGS 

The following instruction timings represent the minimum 
execution time In clock cycles for each Instruction. The timings 
given are based on the following assumptions: 

• The opcode, along with any data or displacement required 
for execution of a particular Instruction, has been pre- 
fetched and resides In the queue at the time It Is needed. 

• No wait states or bus HOLDS occur. 



• All word-data Is located on even-address boundaries. 

All jumps and calls include the time required to fetch the 
opcode of the next instruction at the destination address. 

All instructions which involve memory reference can require 
one (and In some cases, two) additional clocks above the 
minimum timings shown. This Is due to the asynchronous 
nature of the handshake between the BlU and the Execution 
unit. 
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INSTRUCTION SET SUMMARY 


FUNCTION 


FORMAT 


Clock 
Cycles 


Comments 


DATA TRANSFER 
MOV = Move: 

Register to Register/Memory 
Register/memory to register 
Immediate to register/memory 
Immediate to register 
Memory to accumulator 
Accumulator to memory 
Register/memory to segment register 
Segment register to register/memory 

PUSH = Push: 

Memory 

Register 

Segment register 
Immediate 

PUSHA - Push All 

POP = Pop: 

Memory 

Register 

Segment register 

POPA - Pop All 
XCHG = Exchange: 
Register/memory with register 

Register with accumulator 

IN = Input from: 

Fixed port 

Variable port 

OUT = Output to: 

Fixed port 

Variable port 

XLAT = Translate byte to AL 
LEA = Load EA to register 
LDS = Load pointer to DS 
LES = Load pointer to ES 
LAHF=Load AH with flags 
SAHF - Store AH into flags 
PUSHF - Push flags 
POPF - Pop flags 




2/12 

2/9 

12-13 

3-4 

9 

8 

2/9 

2/11 

16 
10 
9 
10 

36 

20 
10 
8 

51 

4/17 
3 

10 
8 

9 
7 
11 
6 
18 
18 
2 
3 
9 
S 


8/16-bit 
8/16-bit 


1 1 w 1 mod reg r/m 1 




1 1 1 w 1 mod reg r/m ] 




1 1 1 1 w 1 mod r/m | data | data if w = 1 | 




1 1 1 w reg | data ( data if w - 1 | 




1 1 w 1 addr-low | addr-high | 




1 1 1 w 1 addr-low | addr-high | 




1 1 1 1 1 mod reg r/m | 




1 1 1 1 mod reg r/m | 




1 1 1 1 1 1 1 1 1 mod 1 1 r/m 1 




10 10 reg | 




reg 1 1 1 




1 1 1 s 1 1 data | data if s = | 




1 10 1 




1 1 1 1 1 1 mod r/m 1 




10 11 reg | 




reg 1 1 1 | (reg^toi) | 




110 1 1 




1 1 1 w 1 mod reg r/m | 




10 10 reg | 




1 1 1 1 w 1 port 1 




1 1 1 1 1 w 1 




1 1 1 1 1 w 1 port 1 




1 1 1 1 1 1 w 1 




110 10 111 1 




10 110 1 1 mod reg r/m | 




110 10 1 1 mod reg r/m | (mod ^t 11) | 




1 1 1 1 mod reg r/m | (moduli) | 




10 11111 1 




1 1 1 1 1 1 




1 1 1 1 1 




10 1110 1 1 




Shaded areas indicate new 801! 
All mnemonics copyright of Intel Corp 


36 Instructions not available In 8086 or 8088 microprocessors. 

1983 







INSTRUCTION SET SUMMARY (Cont'd.) 


FUNCTION 


FORMAT 


Clock 
Cycles 


Comments 


ARITHMETIC 
ADD = Add: 

Reg /memory with register to either 

Immediate to register / memory 

Immediate to accumulator 

ADC = Add with carry: 

Reg/memory with register to either 

Immediate to register/memory 

Immediate to accumulator 

INC = Increment 

Register/ memory 

Register 

SUB = Subtract: 

Reg/memory and register to either 

Immediate from register/memory 

Immediate from accumulator 

SBB = Subtract with borrow: 

Reg/memory and register to either 

Immediate from register/memory 

Immediate from accumulator 

DEC = Decrement: 

Register/memory 

Register 

CMP = Compare: 

Register/ memory with register 

Register with register/memory 

Immediate with register/ memory 

Immediate with accumulator 

NEG = Change sign 

AAA = ASCII adjust for add 

DAA = Decimal adjust for add 

AAS '- ASCII adjust for subtract 

DAS = Decimal adjust for subtract 

MUL = Mulitiply (unsigned) 

Register-Byte 
Register-Word 
Memory-Byte 
Memory-Word 

IMUL = Integer multiply (signed): 

Register-Byte 
Register-Word 
Memory-Byte 

Memory-Word 

IMUL = Integer immediate multiply 
(signed) 




] 


3/10 
4/16 
3/4 

3/10 
4/16 
3/4 

3/15 
3 

3/10 
4/16 
3/4 

3/10 
4/16 
3/4 

3/15 
3 

3/10 
3/10 
3/10 
3/4 

3 

8 

4 

7 

4 

26-28 
35-37 
32-34 
41-43 

25-28 
34-37 
31-34 
40-43 


8/16-bit 
8/16-bit 

e/ie-bit 

8/16-bit 
8/16-bit 


OOOOOOdw 1 mod reg r/m 




1 s w 1 mod r/m 


1 data 1 data if s w - 01 | 






1 w 1 data 


1 data if w = 1 1 




] 


1 d w 1 mod reg r/m 




1 s w 1 mod 10 r/m 


1 data 1 data if s w = 01 | 






1 1 w 1 data 


1 data if w = 1 | 




] 
] 


1 1 1 1 1 1 1 w 1 mod r/m 




10 reg | 




1 1 d w 1 mod reg r/m 




1 s w 1 mod 1 1 r/m 


1 data 1 data if s w = 01 | 






1 1 1 w 1 data 


1 data if w - 1 1 




] 


1 1 d w 1 mod reg r/m 




1 s w 1 mod 1 1 r/m 


1 data 1 data if s w - 01 | 






1 1 1 w 1 data 


1 data if w - 1 1 




] 

] 
] 


1 1 1 1 1 1 1 w 1 mod 1 r/m 




10 1 reg | 




1 1 1 1 w 1 mod reg r/m 




; 1 1 1 w 1 mod reg r/m 




1 s w 1 mod 1 1 1 r/m 


1 data 1 data if s w « 01 | 






1 1 1 1 w 1 data 


1 data if w = 1 1 




] 

] 
] 


1 1 1 1 1 1 w 1 mod 1 1 r/m 




1 1 1 1 1 1 1 




10 111 1 




111111 1 




1 1 1 1 1 1 1 




1 1 1 1 1 1 1 w 1 mod 1 r/m 




1 1 1 1 1 1 1 w 1 mod 1 1 r/m 




jo 1 1 1 s 1 1 mod reg r/m 


[ data 1 data if s = | 


22-25/29-32 








DIV = Divide (unsigned): 

Register- Byte 
Register-Word 
Memory-Byte 
Memory-Word 


1 1 1 1 1 1 1 w 1 mod 1 1 r/m 


] 


29 
38 
35 
44 
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INSTRUCTION SET SUMMARY (Cont'd.] 



FUNCTION 



FORMAT 



Clock 
Cycles 



Comments 



ARITHMETIC (Continued): 

IDIV = Integer divide (signed): 

Register-Byte 
Register-Word 
Memory-Byte 
Memory-Word 

AAM - ASCII adjust for multiply 

AAD = ASCII adjust for divide 

CBW = Convert byte to word 

CWD = Convert vtford to double v/ord 

LOGIC 

Shift/Rotate Instructions: 

Register/Memory by 1 

Register/Memory by CL 

Register/Memory by Count 



1 1 1 1 1 1 1 w 1 mod 1 1 1 r/m | 




|11010100|00001010| 




1 11010101 |ooooioio| 



10 1 10 



10 110 1 



1 1 1 w 



1 1 1 1 w I mod TTT rVrr 



AND = And: 

Reg/memory and register to eittier 

Immediate to register/memory 

Immediate to accumulator 

TEST = And function to flags, no result: 

Register/memory and register 

Immediate data and register/memory 

Immediate data and accumulator 

OR = Or: 

Reg/memory and register to either 

Immediate to register/memory 

Immediate to accumulator 

XOR = Exclusive or: 

Reg/memory and register to either 

Immediate to register/memory 

Immediate to accumulator 

NOT = Invert register/memory 

STRING MANIPULATION: 

MOVS = Move byte/word 

CMPS = Compare byte/word 

SCAS - Scan byte/word 

LCDS = Load byte/wd to AL/AX 

STOS = Stor byte/wd from AL/A 

INS " Input byte/wd from DX port 

OUTS = Output byte/wd to DX port 



1 1 w mod TTT r/m 





1 

1 

1 1 

1 
1 1 
1 1 1 



Instruction 

ROL 
ROR 
RCL 
RCR 
SHL/SAL 
SHR 
SAR 



1 1 d w 1 mod reg r/m | 




1 1 w 1 mod 1 r/m | data | data if w = 1 | 




1 1 1 w 1 data | data if w = 1 | 


: 


1 1 1 w 1 mod reg r/m | 




1 1 1 1 1 1 1 w 1 mod r/m | data | data if w - 1 | 




1 1 1 1 w 1 data 1 data if w - 1 | 




1 1 d w 1 mod reg r/m | 




1 1 w 1 mod 1 r/m | data | data if w = 1 | 




1 1 1 w 1 data 1 data if w = 1 | 




1 1 1 d w 1 mod reg r/m | 




1 1 w 1 mod 1 1 r/m | data | data if w = 1 | 




1 1 1 1 w 1 data 1 data if w - 1 | 




1 1 1 1 1 1 1 w 1 mod 1 r/m | 




1 1 1 1 w 1 




1 1 1 1 1 w I 




1 1 1 1 1 1 w 1 




1 1 1 1 1 w 1 




1 1 1 1 1 w 1 




1 1 1 1 1 w 1 




1 1 1 1 1 1 w 1 



63-61 
50-58 
59-67 

19 
15 
2 

4 



5 + n/17 + n 



3/10 
4/16 
3/4 

3/10 
4/10 
3/4 

3/10 
4/16 
3/4 

3/10 

4/16 

3/4 

3 

8 + 8n 

5 + 22n 
5+15n 
6+11n 

6 + 9n 
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INSTRUCTION SET SUMMARY (Cont'd.) 


FUNCTION 


FORMAT 


Clock 
Cycles 


Comments 


STRING MANIPULATION (Continued): 
Repeated by count in CX 
MOVS - Move string 

CMPS = Compare string 

SCAS = Scan string 

LODS ° Load string 

STOS - Store string 






14 
22 
15 
12 

10 




11110 10 


1 1 1 w 1 






1 1 1 1 1 z 


1 1 1 1 w 1 






1 1 1 1 1 z 


1 1 1 1 1 w 1 






11110 10 


1 1 1 1 w 1 






11110 10 


1 1 1 1 w 1 


INS = Input string 
OUTS ^ Output string 


11110 10 


1 1 1 1 w 1 


8 + 8n/14 
8 + 8n/14 


Repeated/ 
Not Repeated " 

Repeated/ 
Not Repeated 






11110 10 


1 1 1 1 1 w 1 


CONTROL TRANSFER 
CAI 1 = Call: 

Direct wittlin segment 

Register memory 
indirect within segment 

Direct intersegment 

Indirect intersegment 

JMP = Unconditional Jump: 

Short/long 

Direct wittlin segment 

Register/memory indirect within segment 

Direct intersegment 

Indirect intersegment 

RET = Return from CALL: 

Within segment 

Within seg adding immed to SP 

Intersegment 

Intersegment adding immediate to SP 






14 
13/19 

23 

38 

13 

13 

11/17 

13 

26 

16 
18 
22 
25 


1110 10 


disp-low 1 disp-high | 






11111111 


mod 1 r/m | 






10 110 10 


segment offset | 






segment selector 




11111111 


mod 1 1 r/m | (moduli) | 






1110 10 11 


disp.low 1 






1110 10 1 


disp-low 1 disp-high | 






11111111 


mod 1 r/m 






1110 10 10 


segment offset 






segment selector | 




11111111 


mod 1 1 r/m | (mod =^11) | 






110 11 




110 10 


data-low 1 data-high | 






110 10 11 




110 10 10 


data-low 1 data-high | 
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INSTRUCTION SET SUMMARY (Cont'd.) 


FUNCTION 


FORMAT 


Clock 
Cycles 


Comments 


CONTROL TRANSFER (Conlinued): 
JE/JZ = Jump on equal zero 
JL/JNGE = Jump on less not greater or equal 
JLE/JNG = Jump on less or equal not greater 
JB/JNAE = Jump on below not above or equal 
JBE/JNA = Jump on below or equal not above 
JP/JPE = Jump on parity parity even 
JO = Jump on overllow 
JS = Jump on sign 

JNE/JNZ = Jump on not equal not zero 
JNL/JGE = Jump on not less greater or equal 
JNLE/JG = Jump on not less or equal greater 
JNB/JAE = Jump on not below above or equal 
JNBE/JA - Jump on not below or equal above 
JNP/JPO = Jump on not par / par odd 
JNO = Jump on not overflow 
JNS = Jump on not sign 
LOOP - Loop CX times 
LOOPZ/LOOPE - Loop while zero equal 
LOOPNZ/LOOPNE - Loop while not zero equal 
JCXZ = Jump on CX zero 

ENTER - Enter Procedure 

L = 
L=1 
L> 1 

LEAVE - Leave Procedure 

INT = Interrupt: 

Type specified 

Type 3 j 

INTO = Interrupt on overflow 1 

IRET = Interrupt return 






4/13 

4/13 

4/13 

4/13 

4/13 

4/13 

4/13 

4/13 

4/13 

4/13 

4/13 

4/13 

4/13 

4/13 

4/13 

4/13 

5/15 

6/16 

6/16 

16 
5 

15 

25 

22-H6(n-1) 

B 

47 

45 

48/4 

28 

33-35 


13 if JIVIP 

taken 
4 if JfvlP 
not tal<en 

JIVIP tal<en/ 

JMP not laksn 

if INT. taken/ 

if INT. not 
taken 


1110 10 


disp 1 






111110 


disp 1 






1111110 


disp 1 






1110 10 


disp 1 






1110 110 


disp 1 






11110 10 


disp 1 






1110 


disp 1 






11110 


disp 1 






1110 10 1 


disp 1 






111110 1 


disp 1 






1111111 


disp 1 






1110 11 


disp 1 






1110 111 


disp I 






11110 11 


disp 1 






1110 1 


disp 1 






11110 1 


disp 1 






1110 10 


disp 1 






1110 1 


disp 1 






1110 


disp 1 






1110 11 


disp 1 






1 10 10 


data-low | data-high | L | 






110 10 1 




110 110 1 


type 1 






110 110 




110 1110 




110 1111 




BOUND = Detect value out ot range 1 


110 10 


mod rag r/m 
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INSTRUCTION SET SUMMARY (Cont'd.) 



FUNCTION 



FORMAT 



Clock 
Cycles 



Comments 



PROCESSOR CONTROL 

CLC = Clear cswry 

CMC = Complement carry 

STC = Set carry 

CLD = Clear direction 

STD = Set direction 

CLl = Clear interrupt 

STI = Set interrupt 

HLT = Halt 

WAIT -Wait 

LOCK = Bus lock prefix 

ESC = Processor Extension Escape 



1 1 1 1 1 1 1 




1 1 1 1 1 1 1 1 




1 1 1 1 1 1 1 1 




1 1 1 1 1 1 1 1 




1 1 1 1 1 1 1 1 1 




1 1 1 1 1 1 1 1 




1 1 1 1 1 1 1 1 1 




1 1 1 1 1 1 1 




1 10 110 11 1 




1 1 1 1 1 1 




1 1 1 1 T T T 1 mod LLL r/m | 



(TTT LLL are opcode to processor extension) 



FOOTNOTES 

The effective Address (EA) of the memory operand is 
computed according to the mod and r/m fields: 

if mod = 1 1 then r/m is treated as a REG field 

if mod = 00 then DISP = o", disp-low and disp-high are 

absent 

if mod = 01 then DISP = disp-low sign-extended to 16-bits, 

disp-high is absent 

if mod = 10 then DISP = disp-high: disp-low 

if r/m = 000 then EA = (BX) + (SI) + DISP 
if r/m = 001 then EA = (BX) + (Dl) + DISP 
if r/m = 010 then EA = (BP) + (SI) + DISP 
if r/m = 01 1 then EA = (BP) + (Dl) + DISP 
if r/m = 100 then EA = (SI) + DISP 
if r/m = 101 then EA = (Dl) + DISP ^ 
if r/m = 110 then EA = (BP) + DISP* 
if r/m = 1 1 1 then EA = (BX) + DISP 

DISP follows 2nd byte of instruction (before data if required) 

'except if mod = 00 and r/m = 110 then EA = disp-high: disp-low. 

SEGMENT OVERRIDE PREFIX 



1 reg 1 1 



reg is assigned according to the following: 





Segment 


reg 


Register 


00 


ES 


01 


CS 


10 


SS 


11 


DS 



REG is assigned according to the following table: 
16-Bit (w = 1) 8-Bit (w = 0) 



000 AX 


000 AL 


001 CX 


001 CL 


010 DX 


010 DL 


011 BX 


011 BL 


100 SP 


100 AH 


101 BP 


101 OH 


110 SI 


110 DH 


111 Dl 


111 BH 



The physical addresses of all operands addressed by the BP 
register are computed using the SS segment register. The 
physical addresses of the destination operands of the string 
primitive operations (those addressed bythe Dl register) are 
computed using the ES segment, which may not be overrid- 
den. 
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PHYSICAL DIMENSIONS (Cont'd.) 
CGX068 
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